#atlantis (2019-10)
Discuss the Atlantis (<http://runatlantis.io | runatlantis.io>) |
**Archive: ** https://archive.sweetops.com/atlantis/
2019-10-08
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
What was the thing that was like Atlantis, but not?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Can’t find it in the archives
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, i know what you mean.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it had a horrible name
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Turbocharging your infrastructure-as-code
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@joshmyers
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Awesome, thanks @Erik Osterman (Cloud Posse)
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Oh, it’s not OS, https://github.com/geopoiesis?tab=repositories
geopoiesis has 7 repositories available. Follow their code on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Oh… thought it was
2019-10-11
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Am I right in saying the Atlantis workflow is to deploy before the code is merged? Isn’t that a bit sketchy?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Isn’t it sketchy to have code in master that was never deployed? Terraform is crude tool for CRUD that doesn’t rollback in face of errors.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Ah perhaps I have my workflows wrong in my head (purely theoretical, no atlantis deployed yet)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So you are right that I that you should deploy on merge in most cases :-) just I think Atlantis is a good example of when maybe not to do that.
data:image/s3,"s3://crabby-images/6ef30/6ef3026a1f532a8f803d5d809ea13643eb693548" alt="Michael Warkentin avatar"
Yep, atlantis definitely has a deploy-then-merge workflow. The locking helps with the normal issues you’d have with that type of flow (conflicts between multiple branches)
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
@oscar You can require the PR to be approved before changes can be applied, and I believe you can also adjust a setting to have Atlantis merge the code when planning/applying (locally on its side).
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we open a PR and request reviews, atlantis runs plan automatically, the author and the reviewers review the plan, the reviewers approve the PR, we run atlantis apply
, if everything is ok, merge to master
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we want the master to reflect what is deployed, so we merge to master only if everything is ok
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Thanks guys.
So really the workflow isnt to actually comment Atlantis apply
until it has been merged?
Is there a way to enforce this?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
So that someone cant comment and trigger the apply of the plan before merge etc
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yes Atlantis uses a planfile so even if you tried to apply before plan it would fail
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
With Atlantis you run apply before merge
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think there is also an option to auto merge on apply
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So if apply fails it doesn’t merge
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
Still if the atlantis.yaml file lives in your repo, you canc change it in the PR and skip the approval enforcement
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
that’s like one “security issue” i still don’t get
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you deploy atlantis, you provide a global atlantis-repo-config.yaml
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
where you can specify what users in the repo that atlantis provisions can do
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
# allowed_overrides specifies which keys can be overridden by this repo in
# its atlantis.yaml file
allowed_overrides: [apply_requirements, workflow]
# allow_custom_workflows defines whether this repo can define its own
# workflows. If false (default), the repo can only use server-side defined workflows
allow_custom_workflows: true
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(sure if atlantis-repo-config.yaml
is in the same repo (as we have in testing
), it does not solve the issue. But if the atlantis repo is different from the repo it operates on, then you can safely restrict)
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
Nice!!!
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
I’ll look into inplementing
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
thanks @Andriy Knysh (Cloud Posse)
2019-10-15
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
You can also configure branch protection if you’re using GitHub to ensure that the atlantis/plan and apply checks have passed before it’ll allow someone to merge things.
2019-10-21
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Hey all, Im considering using atlantis but I’ve got a few questions(coming from a TFE environment triggered by jenkins).
- How can you differentiate workspaces and credentials? For example, if I commit some changes to git, the terraform plan runs. How can I make the terraform plan and apply against a ‘dev aws environment’ and then have the terraform applied to a prod aws env? How would atlantis differentiate workspaces/secrets?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Id like to use a single repo for all modules/configurations but im a bit hazy on how that would look, for example
git-repo/
module1/
module2/
where would I store configurations for awsdev and awsprod accounts which call those modules? In seperate folders?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
basically, im not sure how to setup atlantis/git for a multi-environment configuration
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we deploy atlantis
on ECS in each account (staging, prod, testing) https://github.com/cloudposse/terraform-aws-ecs-atlantis
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Why not run in one place with assume role?
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we almost always use separate AWS accounts for each environment (dev, staging, prod)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
although more difficult to setup, it adds a lot of benefits including better security, better control, and complete isolation of environments
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
atlantis for provisioning account’s resources goes into the same account
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Aren’t user management and logging exceptions to that?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I assume you have a separate TF state bucket in each account too, then?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
user management is done in a separate account, either root or identity
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
What I mean is that user management is centralized. You could have the same with Atlantis, where it’s running in a separate account but assumes roles and applies changes to individual accounts. That’s what the users do and Atlantis is just a “user” in a sense.
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Example:
provider "aws" {
region = var.region
dynamic "assume_role" {
for_each = [for s in [var.aws_role_name]: s if s != "EXTERNAL"]
content {
role_arn = "arn:aws:iam::${var.aws_account_id}:role/${var.aws_role_name}"
external_id = var.aws_external_id
session_name = module.label.id
}
}
}
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I’m curious what you believe the benefits of separation are for Atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it could be deployed in may diff ways for sure. And what you showed above will work as well
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since we use separate AWS accounts for all environments, we deploy separate atlatis in each
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s not that expensive to deploy an atlantis container on ECS fargate
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but it simplifies management and security
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for example, atlantis-repo-config.yaml
file that describes what users could do https://github.com/cloudposse/testing.cloudposse.co/blob/master/conf/ecs/atlantis-repo-config.yaml
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Thanks, I’m a little on the fence, but I am leaning toward changing to this approach as well
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since we have a separate atlantis for the testing
environment (as we do for prod
, staging
, etc.), it’s just easier to do all those settings on just one repo
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
instead of thinking about how to configure that for many repos for diff environments using just one atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’m not saying it’s the perfect solution, there is no one
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it requires more settings and more deployments
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but it simplifies management, security and all IAM stuff
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
plus, of cause, if something happens with one atlantis (container fails, bad deployment, etc.), it will not affect all the others
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we could test new versions of atlantis in dev/testing first before rolling it to staging/prod
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
That’s a good one. Thanks again.
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
if you have a shared atlantis and that instance is breached, then the attacker would have access to all your accounts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we have a catalog of common modules which we use in all environments https://github.com/cloudposse/terraform-root-modules/tree/master/aws
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in each particular environment, e.g. https://github.com/cloudposse/testing.cloudposse.co, we specify what the atlantis
deployed in testing
could do https://github.com/cloudposse/testing.cloudposse.co/blob/master/atlantis.yaml
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we open a PR, for example in staging
, run atlantis plan
, review and approve the PR, run atlantis apply
and then merge the PR to master at [staging.cloudposse.co](http://staging.cloudposse.co)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then do the same for [prod.cloudposse.co](http://prod.cloudposse.co)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
all secrets we store in SSM param store, and then atlantis
in each environment reads it from SSM using chamber
https://github.com/cloudposse/geodesic/blob/master/rootfs/etc/init.d/atlantis.sh#L44
Geodesic is a cloud automation shell. It's the fastest way to get up and running with a rock solid, production grade cloud platform built on top of strictly Open Source tools. ★ this repo! h…
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
when you say in staging
you mean staging branch?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we have separate repos for each account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they use the same catalog of modules https://github.com/cloudposse/terraform-root-modules/tree/master/aws
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but just provide settings related to the environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we separate code (logic) from settings/secrets