In April 2024, the Core Atlantis Team launched an anonymous survey to better understand our community's needs and help prioritize our roadmap.
If you're an Atlantis user, please take 5 minutes to fill it out: Survey Link
In April 2024, the Core Atlantis Team launched an anonymous survey to better understand our community's needs and help prioritize our roadmap.
If you're an Atlantis user, please take 5 minutes to fill it out: Survey Link
Atlantis triggers commands via pull request comments. 
TIP
You can use following executable names.
atlantis helpatlantis is executable name. You can configure by Executable Name.run helprun is a global executable name.@GithubUser help@GithubUser is the VCS host user which you connected to Atlantis by user token.Currently, Atlantis supports the following commands.
atlantis helpView help
atlantis versionPrint the output of 'terraform version'.
atlantis plan [options] -- [terraform plan flags]Runs terraform plan on the pull request's branch. You may wish to re-run plan after Atlantis has already done so if you've changed some resources manually.
# Runs plan for any projects that Atlantis thinks were modified.
# If an `atlantis.yaml` file is specified, runs plan on the projects that
# were modified as determined by the `when_modified` config.
atlantis plan
# Runs plan in the root directory of the repo with workspace `default`.
atlantis plan -d .
# Runs plan in the `project1` directory of the repo with workspace `default`
atlantis plan -p project1
# Runs plan in the root directory of the repo with workspace `staging`
atlantis plan -w staging-d directory Which directory to run plan in relative to root of repo. Use . for root. atlantis plan -d child/dir-p project Which project to run plan for. Refers to the name of the project configured in the repo's atlantis.yaml file. Cannot be used at same time as -d or -w because the project defines this already.-w workspace Switch to this Terraform workspace before planning. Defaults to default. Ignore this if Terraform workspaces are unused.--verbose Append Atlantis log to comment.NOTE
A atlantis plan (without flags), like autoplans, discards all plans previously created with atlantis plan -p/-d/-w
If terraform plan requires additional arguments, like -target=resource or -var 'foo=bar' or -var-file myfile.tfvars you can append them to the end of the comment after --, ex.
atlantis plan -d dir -- -var foo='bar'If you always need to append a certain flag, see Custom Workflow Use Cases.
To perform a destructive plan that will destroy resources you can use the -destroy flag like this:
atlantis plan -- -destroy
atlantis plan -d dir -- -destroyNOTE
The -destroy flag generates a destroy plan, If this plan is applied it can result in data loss or service disruptions. Ensure that you have thoroughly reviewed your Terraform configuration and intend to remove the specified resources before using this flag.
atlantis apply [options] -- [terraform apply flags]Runs terraform apply for the plan that matches the directory/project/workspace.
TIP
If no directory/project/workspace is specified, ex. atlantis apply, this command will apply all unapplied plans from this pull request. This includes all projects that have been planned manually with atlantis plan -p/-d/-w since the last autoplan or atlantis plan command. For Atlantis commands to work, Atlantis needs to know the location where the plan file is. For that, you can use $PLANFILE which will contain the path of the plan file to be used in your custom steps. i.e terraform plan -out $PLANFILE
# Runs apply for all unapplied plans from this pull request.
atlantis apply
# Runs apply in the root directory of the repo with workspace `default`.
atlantis apply -d .
# Runs apply in the `project1` directory of the repo with workspace `default`
atlantis apply -p project1
# Runs apply in the root directory of the repo with workspace `staging`
atlantis apply -w staging-d directory Apply the plan for this directory, relative to root of repo. Use . for root.-p project Apply the plan for this project. Refers to the name of the project configured in the repo's atlantis.yaml file. Cannot be used at same time as -d or -w.-w workspace Apply the plan for this Terraform workspace. Ignore this if Terraform workspaces are unused.--auto-merge-disabled Disable automerge for this apply command.--verbose Append Atlantis log to comment.Because Atlantis under the hood is running terraform apply plan.tfplan, any Terraform options that would change the plan are ignored, ex:
-target=resource-var 'foo=bar'-var-file=myfile.tfvarsThey're ignored because they can't be specified for an already generated planfile. If you would like to specify these flags, do it while running atlantis plan.
atlantis import [options] ADDRESS ID -- [terraform import flags]Runs terraform import that matches the directory/project/workspace. This command discards the terraform plan result. After an import and before an apply, another atlantis plan must be run again.
To allow the import command requires --allow-commands configuration.
# Runs import
atlantis import ADDRESS ID
# Runs import in the root directory of the repo with workspace `default`
atlantis import -d . ADDRESS ID
# Runs import in the `project1` directory of the repo with workspace `default`
atlantis import -p project1 ADDRESS ID
# Runs import in the root directory of the repo with workspace `staging`
atlantis import -w staging ADDRESS IDTIP
atlantis import 'aws_instance.example["foo"]' i-1234567890abcdef0-d directory Import a resource for this directory, relative to root of repo. Use . for root.-p project Import a resource for this project. Refers to the name of the project configured in the repo's atlantis.yaml repo configuration file. This cannot be used at the same time as -d or -w.-w workspace Import a resource for a specific Terraform workspace. Ignore this if Terraform workspaces are unused.If terraform import requires additional arguments, like -var 'foo=bar' or -var-file myfile.tfvars append them to the end of the comment after --, e.g.
atlantis import -d dir 'aws_instance.example["foo"]' i-1234567890abcdef0 -- -var foo='bar'If a flag is needed to be always appended, see Custom Workflow Use Cases.
atlantis state [options] rm ADDRESS... -- [terraform state rm flags]Runs terraform state rm that matches the directory/project/workspace. This command discards the terraform plan result. After run state rm and before an apply, another atlantis plan must be run again.
To allow the state command requires --allow-commands configuration.
# Runs state rm
atlantis state rm ADDRESS1 ADDRESS2
# Runs state rm in the root directory of the repo with workspace `default`
atlantis state -d . rm ADDRESS
# Runs state rm in the `project1` directory of the repo with workspace `default`
atlantis state -p project1 rm ADDRESS
# Runs state rm in the root directory of the repo with workspace `staging`
atlantis state -w staging rm ADDRESSTIP
atlantis state rm 'aws_instance.example["foo"]'-d directory Run state rm a resource for this directory, relative to root of repo. Use . for root.-p project Run state rm a resource for this project. Refers to the name of the project configured in the repo's atlantis.yaml repo configuration file. This cannot be used at the same time as -d or -w.-w workspace Run state rm a resource for a specific Terraform workspace. Ignore this if Terraform workspaces are unused.If terraform state rm requires additional arguments, like -lock=false' append them to the end of the comment after --, e.g.
atlantis state -d dir rm 'aws_instance.example["foo"]' -- -lock=falseIf a flag is needed to be always appended, see Custom Workflow Use Cases.
atlantis unlockRemoves all atlantis locks and discards all plans for this PR. To unlock a specific plan you can use the Atlantis UI.
atlantis approve_policiesApproves all current policy checking failures for the PR.
See also policy checking.
--verbose Append Atlantis log to comment.