#gitops (2018-10)
Discuss continuous delivery of infrastructure
Archive: https://archive.sweetops.com/gitops/
2018-10-01
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
@jarv has joined the channel
2018-10-02
data:image/s3,"s3://crabby-images/22ae3/22ae3acdb8e4f9a22267bf68af5deaab4924fda5" alt="mallen avatar"
@mallen has joined the channel
2018-10-03
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hi everyone, I wonder how most of you are doing secrets management. In a stack I’m working on the applications their env vars (ssm) are populated through terraform. Secrets like API keys are also stored in git but have been encrypted by KMS. Those secrets will be decrypted by terraform using aws_kms_secrets. My belief is that this is secure as envelope encryption would make the encrypted hash useless without access to KMS, next to that it makes it possible to version everything related to the application and removes manually entering passwords to SSM. @Erik Osterman (Cloud Posse) pointed out to me that git is about transparency and that storing anything else than readable text is a conflict. For me this is less of a problem when the alternative is to manually enter passwords. Happy to collect your thoughts.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
@pecigonzalo has joined the channel
data:image/s3,"s3://crabby-images/90473/90473014969c985f6bcbd07799dd61093a339936" alt="jonboulle avatar"
@jonboulle has joined the channel
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
@jamie has joined the channel
data:image/s3,"s3://crabby-images/90473/90473014969c985f6bcbd07799dd61093a339936" alt="jonboulle avatar"
git isn’t just about transparency in terms of content, it’s about transparency in terms of an audit log of changes, which this still provides. of course you can get that with other systems too, but isn’t the point of gitops to have all of that centralised in git?
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
@Steven has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jonboulle in principle I agree with you. but stoking debate, where is the line drawn? what about binary artifacts from build processes or packages?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for example, a common pattern I dislike, but which has emerged with terraform+lambda, is including a zip
of the lambda and all dependencies (E.g. npm packages) and sticking it in git. this obscures what is there and precludes effective code reviews.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@maarten in the end, I don’t have a better solution than what you proposed. i still dislike binary assets in git, but like with images it’s a necessary tradeoff sometimes. i think it’s technically sound strategy and quite elegant if you get it working end-to-end.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/c2250/c2250bb12dfca0018415a5417e3b714c06b44554" alt="attachment image"
Our philosophy and approach to production secret management
data:image/s3,"s3://crabby-images/90473/90473014969c985f6bcbd07799dd61093a339936" alt="jonboulle avatar"
I don’t think it’s hard to draw the line; artifacts from build processes belong in blob stores (e.g. package repository or image repository). ideally the store is a CAS. then git can house a reference to them as necessary
data:image/s3,"s3://crabby-images/90473/90473014969c985f6bcbd07799dd61093a339936" alt="jonboulle avatar"
you’ll find no disagreement from me on storing a lambda zip being an antipattern
data:image/s3,"s3://crabby-images/90473/90473014969c985f6bcbd07799dd61093a339936" alt="jonboulle avatar"
but to push back on “storing anything else than readable text is a conflict” (not sure if you directly said this or it’s a paraphrase - so apologies for the potential strawman!) - there are plenty of cases of these kinds of content-addressable references (e.g. docker image SHA, Gemfile.lock, whatever) where they should definitely be stored in git but they can hardly qualify as “readable text” in themselves
2018-10-04
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Andriy Knysh (Cloud Posse) thanks.. I responded to the article as this is a step away from factor12. But with their java background env variables were probably something they have never used to begin with.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@maarten insightful comment
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"
this is a good point
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what is your approach to this in what you’re doing?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g. if you have the “widget” app and you encrypt the “prod” mailgun key and commit to source control in the widget app repo, is this blurring the line?
data:image/s3,"s3://crabby-images/73f7a/73f7a9b16d513365921c22ac714c01731e99e48b" alt="daveyu avatar"
@daveyu has joined the channel
data:image/s3,"s3://crabby-images/908e0/908e047829a334ae81285b49bd79cf30644d5ba9" alt="wave"
2018-10-07
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for those interested and want to follow along, we’re working on some enhancements for atlantis
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform For Teams. Contribute to cloudposse/atlantis development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’ve added atlantis
to our alpine repository:
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
curl -sSL <https://apk.cloudposse.com/install.sh> | sudo bash
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
And the work for integrating it into geodesic: https://github.com/cloudposse/geodesic/pull/298/files
what Add support for atlantis why GitOps style continuous delivery for infrastructure
2018-10-08
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
@antonbabenko has joined the channel
data:image/s3,"s3://crabby-images/fb0d3/fb0d35c35b9095b1bb5ad6eb3405cb4c9f7b3234" alt="rohit.verma avatar"
@rohit.verma has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ah let me remove article with jpg
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
replace*
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
AirBNB response to my question about having secrets coupled into Docker. Having secrets maintained away from the application makes it impossible to do an actual rollback to point an application to the previous config set which is a point.
I’m thinking of a way to make SSM/KMS/Chamber compatible with the mindset of that issue at stake.
SSM
/service/db_host = 'hostA'
/service/db_user = 'userA'
/service/db_host_migration = 'hostB'
/service/db_user_migration = 'userB'
On the Docker with Chamber /etc/chamber_rewrites
( or defined ENV ) defines how certain env vars can be rewritten with other created env vars.
db_host = db_host_migration
db_user = db_user_migration
This way it is possible to work with a default config set, yet it is still possible to fix config values to a certain deployment. Problem here is transparency, it is not visible from the outside which docker is using what.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
re:
/service/db_host = 'hostA'
/service/db_user = 'userA'
/service/db_host_migration = 'hostB'
/service/db_user_migration = 'userB'
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
why not use different service namespaces
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
/service/db_host = 'hostA'
/service/db_user = 'userA'
/service/migation/db_host = 'hostB'
/service/migration/db_user = 'userB'
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
TBH, I did think of that too, but I’m afraid that would kill their parser a bit.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
their = chamber?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
yes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hrm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
true, i think their import/export only handles one service namespace at a time
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
checking
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
i mean, db_host is attribute here, migation/db_host is a nested attribute but has a / in it. I don’t think / are allowed
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
inside the name
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and a full real namespace change, as in, changing the prefix of everything SSM, or a different service name. That of course can work. BUT. you would need to modify iam policies for the service to allow access to it, and I think that is just too much change for something trivial.
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"
anyways, what i was actually hoping was that the export format supported the service namespace
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but it doesn’t
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so to your point
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I mean, by changing the full service path, and making it a level deeper more or less, you can make it to work but you would need to duplicate everything to that level deeper
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i think a cool/needed tool would be a chamber ETL tool with KMS (PKE) support
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that maybe supports some custom mapping
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(since i don’t think the guys at chamber are too amenable to changes of this nature)
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Maybe yes, but it’s an interesting quest to drop and see what comes out.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
despite my previous reservations, I think I am leaning still towards your approach
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Better ( but impossible to get ) is a new style SSM with versioned change-sets which can be referred to.
2018-10-09
data:image/s3,"s3://crabby-images/e6a92/e6a926a549d4a2f3a2ca55c25ec5857e4e625e5b" alt="stephen avatar"
@stephen has joined the channel
data:image/s3,"s3://crabby-images/1a4b2/1a4b2bc19410d0f2cf7913ea0ff0cc7bf8a915a2" alt="Adam avatar"
@Adam has joined the channel
data:image/s3,"s3://crabby-images/62f1e/62f1e64c738b7e1ff71bbc7fce2ce252f682cb4d" alt="Yoann avatar"
@Yoann has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@antonbabenko @maarten any companies you know of using atlantis that I can reference in my slides?
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
I don’t remember names. They were pretty small and unknown.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Thanks anyways :)
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Blinkist.com , need to ask the other two for OK
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok, great, I’ll add them - thanks!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
When is it due?
2018-10-10
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
4 votes and 1 comment so far on Reddit
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
Send a email to Luke to get more names.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Talking 10/25
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2018-10-11
data:image/s3,"s3://crabby-images/4438c/4438c752e9f16aa7251150988d3164e3923be64f" alt="ben avatar"
@ben has joined the channel
2018-10-13
data:image/s3,"s3://crabby-images/554d2/554d26fd23e2a82ee3a09831b7e6cb353031b7ef" alt="Gaurav avatar"
@Gaurav has joined the channel
2018-10-14
data:image/s3,"s3://crabby-images/c9c5d/c9c5d2752e126d4879f1941e7df26b52bb2ec302" alt="fdrescher avatar"
@fdrescher has joined the channel
2018-10-22
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I added a #atlantis channel since we’re doing a lot more with it these days (related to runatlantis.io).
2018-10-24
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
continuing this discussion https://sweetops.slack.com/archives/CBW0HJDS8/p1539711018000100
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
nice article https://css-tricks.com/introducing-github-actions/
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they will have a service to add encrypted secrets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you could use ENV vars
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and you’ll be able to create actions programmatically
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
workflow "New workflow" {
on = "push"
resolves = ["Deploy to Azure"]
}
action "Deploy to Azure" {
uses = "./.github/azdeploy"
secrets = ["SERVICE_PASS"]
env = {
SERVICE_PRINCIPAL="<http://sdrasApp>",
TENANT_ID="72f988bf-86f1-41af-91ab-2d7cd011db47",
APPID="sdrasMoonshine"
}
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
looks like Terraform HCL
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea that’s 100% :-)