Use atomic deploys to coordinate changes to your tasks and your application.
Atomic deploys in Trigger.dev allow you to synchronize the deployment of your application with a specific version of your tasks. This ensures that your application always uses the correct version of its associated tasks, preventing inconsistencies or errors due to version mismatches.
Atomic deploys achieve synchronization by deploying your tasks to Trigger.dev without promoting them to the default version. Instead, you explicitly specify the deployed task version in your application’s environment. Here’s the process at a glance:
--skip-promotion
flag. This creates a new task version without making it the default.TRIGGER_VERSION
to the captured task version.If you deploy to Vercel via their CLI, you can use this sample workflow that demonstrates performing atomic deploys with GitHub Actions, Trigger.dev, and Vercel:
Deploy to Trigger.dev
npx trigger.dev deploy
command uses --skip-promotion
to deploy the tasks without setting the version as the default.deploy-trigger
allows us to capture the deployment version in the output (deploymentVersion).Deploy to Vercel:
npx vercel
command deploys the application, setting the TRIGGER_VERSION
environment variable to the task version from the previous step.@trigger.dev/sdk
automatically uses the TRIGGER_VERSION
environment variable to trigger the correct version of the tasks.For this workflow to work, you need to set up the following secrets in your GitHub repository:
TRIGGER_ACCESS_TOKEN
: Your Trigger.dev personal access token. View the instructions here to learn more.VERCEL_TOKEN
: Your Vercel personal access token. You can find this in your Vercel account settings.If you’re are using Vercel, chances are you are using their GitHub integration and deploying your application directly from pushes to GitHub. This section covers how to achieve atomic deploys with Trigger.dev in this setup.
By default, Vercel automatically promotes new deployments to production. To prevent this, you need to disable the auto-promotion feature in your Vercel project settings:
https://vercel.com/<team-slug>/<project-slug>/settings/environments/production
Now whenever you push to your main branch, Vercel will deploy your application to the production environment without promoting it, and you can control the promotion manually.
Now we want to deploy that same commit to Trigger.dev, and then promote the Vercel deployment when that completes. Here’s a sample GitHub Actions workflow that does this:
This workflow does the following:
ludalex/vercel-wait
action.npx trigger.dev deploy
command. There’s no need to use the --skip-promotion
flag because we want to promote the deployment.npx vercel promote
command.For this workflow to work, you need to set up the following secrets in your GitHub repository:
TRIGGER_ACCESS_TOKEN
: Your Trigger.dev personal access token. View the instructions here to learn more.VERCEL_TOKEN
: Your Vercel personal access token. You can find this in your Vercel account settings.VERCEL_PROJECT_ID
: Your Vercel project ID. You can find this in your Vercel project settings.VERCEL_SCOPE_NAME
: Your Vercel team slug.Checkout our example repo to see this workflow in action.
We are using the ludalex/vercel-wait
action above as a fork of the official
tj-actions/vercel-wait action because there is a bug
in the official action that exits early if the deployment isn’t found in the first check and due
to the fact that it supports treating skipped (cancelled) Vercel deployments as valid (on by default).
I’ve opened a PR for this issue here.