Environment variables
When the agent invokes your build scripts it passes in a set of standard Buildkite environment variables, along with any that you've defined in your build configuration. You can use these environment variables in your build steps and job lifecycle hooks.
For best practices and recommendations about using secrets in your environment variables, see the Managing secrets guide.
Buildkite environment variables
The following environment variables may be visible in your commands, plugins, and hooks.
Note that GitHub accepts unsigned commits, including information about the commit author and passes them along to webhooks, so you should not rely on these for authentication unless you are confident that all of your commits are trusted.
BUILDKITE #
This value cannot be modified
|
Always |
---|---|
BUILDKITE_AGENT_ACCESS_TOKEN #
This value cannot be modified
|
The agent session token for the job. The variable is read by the agent
Example:
|
BUILDKITE_AGENT_DEBUG #
|
The value of the |
BUILDKITE_AGENT_DISCONNECT_AFTER_JOB #
|
The value of the |
BUILDKITE_AGENT_DISCONNECT_AFTER_IDLE_TIMEOUT #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_AGENT_ENDPOINT #
Default:
|
The value of the |
BUILDKITE_AGENT_EXPERIMENT #
This value cannot be modified
|
A list of the experimental agent features that are currently enabled. The value can be set using the
Example:
|
BUILDKITE_AGENT_HEALTH_CHECK_ADDR #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_AGENT_ID #
This value cannot be modified
|
The UUID of the agent.
Example:
|
BUILDKITE_AGENT_META_DATA_* #
This value cannot be modified
|
The value of each agent tag. The tag name is appended to the end of the variable name. They can be set using the
Example:
|
BUILDKITE_AGENT_NAME #
This value cannot be modified
|
The name of the agent that ran the job.
Example:
|
BUILDKITE_AGENT_PID #
This value cannot be modified
|
The process ID of the agent.
Example:
|
BUILDKITE_ARTIFACT_PATHS #
|
The artifact paths to upload after the job, if any have been specified. The value can be modified by exporting the environment variable in the
Example:
|
BUILDKITE_ARTIFACT_UPLOAD_DESTINATION #
|
The path where artifacts will be uploaded. This variable is read by the
Example:
|
BUILDKITE_BIN_PATH #
This value cannot be modified
|
The path to the directory containing the
Example:
|
BUILDKITE_BRANCH #
This value cannot be modified
|
The branch being built. Note that for manually triggered builds, this branch is not guaranteed to contain the commit specified by
Example:
|
BUILDKITE_BUILD_CHECKOUT_PATH #
This value cannot be modified
|
The path where the agent has checked out your code for this build. This variable is read by the bootstrap when the agent is started, and can only be set by exporting the environment variable in the
Example:
|
BUILDKITE_BUILD_AUTHOR #
This value cannot be modified
|
The name of the user who authored the commit being built. May be unverified. This value can be blank in some situations, including builds manually triggered using API or Buildkite web interface.
Example:
|
BUILDKITE_BUILD_AUTHOR_EMAIL #
This value cannot be modified
|
The notification email of the user who authored the commit being built. May be unverified. This value can be blank in some situations, including builds manually triggered using API or Buildkite web interface.
Example:
|
BUILDKITE_BUILD_CREATOR #
This value cannot be modified
|
The name of the user who created the build. The value differs depending on how the build was created:
Example:
|
BUILDKITE_BUILD_CREATOR_EMAIL #
This value cannot be modified
|
The notification email of the user who created the build. The value differs depending on how the build was created:
Example:
|
BUILDKITE_BUILD_CREATOR_TEAMS #
This value cannot be modified
|
A colon separated list of non-private team slugs that the build creator belongs to. The value differs depending on how the build was created:
Example:
|
BUILDKITE_BUILD_ID #
This value cannot be modified
|
The UUID of the build.
Example:
|
BUILDKITE_BUILD_NUMBER #
This value cannot be modified
|
The build number. This number increases with every build, and is guaranteed to be unique within each pipeline.
Example:
|
BUILDKITE_BUILD_PATH #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_BUILD_URL #
This value cannot be modified
|
The url for this build on Buildkite.
Example:
|
BUILDKITE_CANCEL_GRACE_PERIOD #
Default:
|
The value of the |
BUILDKITE_CANCEL_SIGNAL #
Default:
|
The value of the |
BUILDKITE_CLEAN_CHECKOUT #
|
Whether the build should perform a clean checkout. The variable is read during the default checkout phase of the bootstrap and can be overridden in |
BUILDKITE_CLUSTER_ID #
This value cannot be modified
|
The UUID value of the cluster, but only if the build has an associated
Example:
|
BUILDKITE_COMMAND #
This value cannot be modified
|
The command that will be run for the job.
Example:
|
BUILDKITE_COMMAND_EVAL #
|
The opposite of the value of the |
BUILDKITE_COMMAND_EXIT_STATUS #
This value cannot be modified
|
The exit code from the last command run in the command hook.
Example:
|
BUILDKITE_COMMIT #
This value cannot be modified
|
The git commit object of the build. This is usually a 40-byte hexadecimal SHA-1 hash, but can also be a symbolic name like
Example:
|
BUILDKITE_CONFIG_PATH #
Default:
|
The path to the agent config file. |
BUILDKITE_ENV_FILE #
This value cannot be modified
|
The path to the file containing the job's environment variables.
Example:
|
BUILDKITE_GIT_CLEAN_FLAGS #
|
The value of the
Example:
|
BUILDKITE_GIT_CLONE_FLAGS #
|
The value of the
Example:
|
BUILDKITE_GIT_SUBMODULES #
|
The opposite of the value of the |
BUILDKITE_GITHUB_DEPLOYMENT_ID #
This value cannot be modified
|
The GitHub deployment ID. Only available on builds triggered by a GitHub Deployment.
Example:
|
BUILDKITE_GITHUB_DEPLOYMENT_ENVIRONMENT #
This value cannot be modified
|
The name of the GitHub deployment environment. Only available on builds triggered by a GitHub Deployment.
Example:
|
BUILDKITE_GITHUB_DEPLOYMENT_TASK #
This value cannot be modified
|
The name of the GitHub deployment task. Only available on builds triggered by a GitHub Deployment.
Example:
|
BUILDKITE_GITHUB_DEPLOYMENT_PAYLOAD #
This value cannot be modified
|
The GitHub deployment payload data as serialized JSON. Only available on builds triggered by a GitHub Deployment.
Example:
|
BUILDKITE_GROUP_ID #
This value cannot be modified
|
The UUID of the group step the job belongs to. This variable is only available if the job belongs to a group step.
Example:
|
BUILDKITE_GROUP_KEY #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_GROUP_LABEL #
This value cannot be modified
|
The label/name of the group step the job belongs to. This variable is only available if the job belongs to a group step.
Example:
|
BUILDKITE_HOOKS_PATH #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_IGNORED_ENV #
This value cannot be modified
|
A list of environment variables that have been set in your pipeline that are protected and will be overridden, used internally to pass data from the bootstrap to the agent.
Example:
|
BUILDKITE_JOB_ID #
This value cannot be modified
|
The internal UUID Buildkite uses for this job.
Example:
|
BUILDKITE_JOB_LOG_TMPFILE #
This value cannot be modified
|
The path to a temporary file containing the logs for this job. Requires enabling the
Example:
|
BUILDKITE_LABEL #
This value cannot be modified
|
The label/name of the current job.
Example:
|
BUILDKITE_LAST_HOOK_EXIT_STATUS #
This value cannot be modified
|
The exit code of the last hook that ran, used internally by the hooks.
Example:
|
BUILDKITE_LOCAL_HOOKS_ENABLED #
|
The opposite of the value of the |
BUILDKITE_MESSAGE #
This value cannot be modified
|
The message associated with the build, usually the commit message. The value is empty when a message is not set. For example, when a user triggers a build from the Buildkite dashboard without entering a message, the variable returns an empty value.
Example:
|
BUILDKITE_ORGANIZATION_SLUG #
This value cannot be modified
|
The organization name on Buildkite as used in URLs.
Example:
|
BUILDKITE_PARALLEL_JOB #
This value cannot be modified
|
The index of each parallel job created from a parallel build step, starting from 0. For a build step with
Example:
|
BUILDKITE_PARALLEL_JOB_COUNT #
This value cannot be modified
|
The total number of parallel jobs created from a parallel build step. For a build step with
Example:
|
BUILDKITE_PIPELINE_DEFAULT_BRANCH #
This value cannot be modified
|
The default branch for this pipeline.
Example:
|
BUILDKITE_PIPELINE_NAME #
This value cannot be modified
|
The displayed pipeline name on Buildkite.
Example:
|
BUILDKITE_PIPELINE_PROVIDER #
This value cannot be modified
|
The ID of the source code provider for the pipeline's repository.
Example:
|
BUILDKITE_PIPELINE_SLUG #
This value cannot be modified
|
The pipeline slug on Buildkite as used in URLs.
Example:
|
BUILDKITE_PIPELINE_TEAMS #
This value cannot be modified
|
A colon separated list of the pipeline's non-private team slugs.
Example:
|
BUILDKITE_PLUGIN_CONFIGURATION #
This value cannot be modified
|
A JSON string holding the current plugin's configuration (as opposed to all the plugin configurations in the
Example:
|
BUILDKITE_PLUGIN_NAME #
This value cannot be modified
|
The current plugin's name, with all letters in uppercase and any spaces replaced with underscores.
Example:
|
BUILDKITE_PLUGINS #
This value cannot be modified
|
A JSON object containing a list plugins used in the step, and their configuration.
Example:
|
BUILDKITE_PLUGINS_ENABLED #
|
The opposite of the value of the |
BUILDKITE_PLUGINS_PATH #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_PLUGIN_VALIDATION #
Default:
|
Whether to validate plugin configuration and requirements. The value can be modified by exporting the environment variable in the |
BUILDKITE_PULL_REQUEST #
This value cannot be modified
|
The number of the pull request or
Example:
|
BUILDKITE_PULL_REQUEST_BASE_BRANCH #
This value cannot be modified
|
The base branch that the pull request is targeting or
Example:
|
BUILDKITE_PULL_REQUEST_DRAFT #
This value cannot be modified
|
Set to
Example:
|
BUILDKITE_PULL_REQUEST_REPO #
This value cannot be modified
|
The repository URL of the pull request or
Example:
|
BUILDKITE_REBUILT_FROM_BUILD_ID #
This value cannot be modified
|
The UUID of the original build this was rebuilt from or
Example:
|
BUILDKITE_REBUILT_FROM_BUILD_NUMBER #
This value cannot be modified
|
The number of the original build this was rebuilt from or
Example:
|
BUILDKITE_REFSPEC #
|
A custom refspec for the buildkite-agent bootstrap script to use when checking out code. This variable can be modified by exporting the environment variable in the
Example:
|
BUILDKITE_REPO #
|
The repository of your pipeline. This variable can be set by exporting the environment variable in the
Example:
|
BUILDKITE_REPO_MIRROR #
This value cannot be modified
|
The path to the shared git mirror. Introduced in v3.47.0.
Example:
|
BUILDKITE_RETRY_COUNT #
This value cannot be modified
|
How many times this job has been retried.
Example:
|
BUILDKITE_S3_ACCESS_KEY_ID #
This value cannot be modified
|
The access key ID for your S3 IAM user, for use with private S3 buckets. The variable is read by the
Example:
|
BUILDKITE_S3_ACCESS_URL #
This value cannot be modified
|
The access URL for your private S3 bucket, if you are using a proxy. The variable is read by the
Example:
|
BUILDKITE_S3_ACL #
Default:
|
The Access Control List to be set on artifacts being uploaded to your private S3 bucket. The variable is read by the Must be one of the following values which map to S3 Canned ACL grants. |
BUILDKITE_S3_DEFAULT_REGION #
Default:
|
The region of your private S3 bucket. The variable is read by the |
BUILDKITE_S3_SECRET_ACCESS_KEY #
This value cannot be modified
|
The secret access key for your S3 IAM user, for use with private S3 buckets. The variable is read by the
Example:
|
BUILDKITE_S3_SSE_ENABLED #
Default:
|
Whether to enable encryption for the artifacts in your private S3 bucket. The variable is read by the |
BUILDKITE_SHELL #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_SOURCE #
|
The source of the event that created the build. |
BUILDKITE_SSH_KEYSCAN #
|
The opposite of the value of the |
BUILDKITE_STEP_ID #
This value cannot be modified
|
A unique string that identifies a step.
Example:
|
BUILDKITE_STEP_KEY #
This value cannot be modified
|
The value of the
Example:
|
BUILDKITE_TAG #
This value cannot be modified
|
The name of the tag being built, if this build was triggered from a tag.
Example:
|
BUILDKITE_TIMEOUT #
This value cannot be modified
|
The number of minutes until Buildkite automatically cancels this job, if a timeout has been specified, otherwise it
Example:
|
BUILDKITE_TRACING_BACKEND #
Default:
|
Set to Also available as a buildkite agent configuration option.
Example:
|
BUILDKITE_TRIGGERED_FROM_BUILD_ID #
This value cannot be modified
|
The UUID of the build that triggered this build. This will be empty if the build was not triggered from another build.
Example:
|
BUILDKITE_TRIGGERED_FROM_BUILD_NUMBER #
This value cannot be modified
|
The number of the build that triggered this build or
Example:
|
BUILDKITE_TRIGGERED_FROM_BUILD_PIPELINE_SLUG #
This value cannot be modified
|
The slug of the pipeline that was used to trigger this build or
Example:
|
BUILDKITE_UNBLOCKER #
This value cannot be modified
|
The name of the user who unblocked the build.
Example:
|
BUILDKITE_UNBLOCKER_EMAIL #
This value cannot be modified
|
The notification email of the user who unblocked the build.
Example:
|
BUILDKITE_UNBLOCKER_ID #
This value cannot be modified
|
The UUID of the user who unblocked the build.
Example:
|
BUILDKITE_UNBLOCKER_TEAMS #
This value cannot be modified
|
A colon separated list of non-private team slugs that the user who unblocked the build belongs to.
Example:
|
CI #
This value cannot be modified
|
Always |
Deprecated environment variables
The following environment variables have been deprecated.
BUILDKITE_PROJECT_PROVIDER |
This has been renamed to BUILDKITE_PIPELINE_PROVIDER . |
---|---|
BUILDKITE_PROJECT_SLUG |
This has been renamed to BUILDKITE_PIPELINE_SLUG . |
BUILDKITE_SCRIPT_PATH |
This has been renamed to BUILDKITE_COMMAND
|
BUILDKITE_STEP_IDENTIFIER |
This has been renamed to BUILDKITE_STEP_KEY
|
BUILDBOX_AGENT_ID |
This has been renamed to BUILDKITE_AGENT_ID
|
BUILDBOX_AGENT_NAME |
This has been renamed to BUILDKITE_AGENT_NAME
|
BUILDBOX_AGENT_META_DATA_* |
This has been renamed to BUILDKITE_AGENT_META_DATA_*
|
BUILDBOX_AGENT_ACCESS_TOKEN |
This has been renamed to BUILDKITE_AGENT_ACCESS_TOKEN
|
BUILDBOX_AGENT_API_URL |
This has been removed with no replacement |
Defining your own
You can define environment variables in your jobs in a few ways, depending on the nature of the value being set:
- Pipeline settings — for values that are not secret.
- Build pipeline configuration — for values that are not secret.
- An
environment
orpre-command
agent hook — for values that are secret or agent-specific.
Secrets in environment variables
Do not print or export secrets in your pipelines. See the Secrets documentation for further information and best practices.
Variable interpolation
Any environment variables set by Buildkite will be interpolated by the Agent.
If you're using the YAML Steps editor to define your pipeline, only the following subset of the environment variables are available:
BUILDKITE_BRANCH
BUILDKITE_TAG
BUILDKITE_MESSAGE
BUILDKITE_COMMIT
BUILDKITE_PIPELINE_SLUG
BUILDKITE_PIPELINE_NAME
BUILDKITE_PIPELINE_ID
BUILDKITE_ORGANIZATION_SLUG
BUILDKITE_TRIGGERED_FROM_BUILD_PIPELINE_SLUG
BUILDKITE_REPO
BUILDKITE_PULL_REQUEST
BUILDKITE_PULL_REQUEST_BASE_BRANCH
BUILDKITE_PULL_REQUEST_REPO
Some variables, for example BUILDKITE_BUILD_NUMBER
, cannot be supported in the YAML Step editor as the interpolation happens before the build is created. In those cases, interpolate them at the runtime.
Alternatively, You can also access the rest of the Buildkite environment variables by using a pipeline.yml
file. Either define your entire pipeline in the YAML file, or you do a pipeline upload part way through your build that adds only the steps that use environment variables. See the dynamic pipelines docs for more information about adding steps with pipeline uploads.
Runtime variable interpolation
When using environment variables that will be evaluated at run-time, make sure you escape the $
character using $$
or \$
. For example:
- command: "deploy.sh $$SERVER"
env:
SERVER: "server-a"
Further details about environment variable interpolation can be found in the pipeline upload CLI guide.
Environment variable precedence
You can set environment variables in lots of different places, and which ones take precedence can get a little confusing. There are many different levels at which environment variables are merged together. The following walkthrough and examples demonstrate the order in which variables are combined, as if you had set variables in every available place.
Job environment
When a job runs on an agent, the first combination of environment variables happens in the job environment itself. This is the environment you can see in a job's Environment tab in the Buildkite dashboard, and the one returned by the REST and GraphQL APIs.
If you are not using YAML Steps, the precedence of environment variables is different from the list below.
Please migrate your pipelines to use YAML steps.
The job environment is made by merging the following sets of values, where values in each successive set take precedence:
Pipeline | Optional variables set by you on a pipeline on the Pipeline Settings page |
---|---|
Build | Optional variables set by you on the build when creating a new build in the UI or using the REST API |
Step | Optional variables set by you on a step in the YAML steps editor or a pipeline.yml file |
Standard | The set of variables provided by Buildkite to every job |
For example, if you had configured the following environment variables:
Pipeline | MY_ENV1="a" |
---|---|
Build | MY_ENV1="b" |
Step | MY_ENV1="c" |
In the final job environment, the value of MY_ENV1
would be "c"
.
Setting variables in a pipeline.yml
There are two places in a pipeline.yml file that you can set environment variables:
- In the
env
attribute of command and trigger steps. - In the
env
attribute at the top of the yaml file, before you define your pipeline's steps.
Defining an environment variable at the top of your yaml file will set that variable on each of the command steps in the pipeline, and is equivalent to setting the env
attribute on every step. This includes further pipeline uploads through buildkite-agent pipeline upload
.
Top level pipeline environment variables will override what is set in the env
attribute of an individual step.
Setting variables in a Trigger step
Environment variables are not automatically passed through to builds created with trigger steps. To set build-level environment variables on triggered builds, set the trigger step's env
attribute.
Agent environment
Separate to the job's base environment, your buildkite-agent
process has an environment of its own. This is made up of:
- operating system environment variables
- any variables you set on your agent when you started it
- any environment variables that were inherited from how you started the process (for example, systemd sets some env vars for you)
For a list of variables and configuration flags, you can set on your agent, see the Buildkite agent's start command documentation.
Job runtime environment
Once the job is accepted by an agent, more environment merging happens. Starting with the environment that we put together in the Job Environment section, we merge in some of the variables from the agent environment.
Not all variables from the agent are available in the job runtime. For example, we remove the agent's registration token and replace it with a build session token that has limited permissions. This new session token is used when you run the artifact
, meta-data
and pipeline
commands inside the job.
After the agent variables have been merged, the bootstrap script is run.
The bootstrap runs any hooks that have been defined by your agent, your repository or plugins. Variables that are set in these hooks will be merged into the runtime environment, and will override any previous values that are set.
Take care with environment variables in hooks
Variables that are defined in hooks can override anything that exists in the environment.
This is the environment your command runs in 🎉
Finally, if your job's commands make any changes to the environment, those changes will only survive as long as the script is running.