#release-engineering (2018-11)
All things CI/CD. Specific emphasis on Codefresh and CodeBuild with CodePipeline.
CI/CD Discussions
Archive: https://archive.sweetops.com/release-engineering/
2018-11-01
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Ah bah, no :superfresh:
emoji.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we can add that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for those that don’t know dustin, he is an awesome support engineer at Codefresh, which is what we use for all of our CI/CD
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @dustinvb
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Hi Andriy.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Happy to help out in anyway I can.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we all love Codefresh
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
I do as well. Was a customer for a year before joining.
2018-11-06
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Howdy releasers
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I wanted to discuss one topic that is spinning in my head for a while:
- Reusing docker or other artifacts from PRs or not
Basically, so speed up the build/release cycle, I was thinking on reusing the tested/built artifact in a PR when we deploy to the QA environment and ofcourse subsequently
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes, reusing the docker image is ideal for deployment to production and preproduction
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we tend to treat preproduction and staging slightly different
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
staging ~ master
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
preproduction is a tagged release
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that tagged release gets promoted to production repos
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
but do you build it on PR as well? if you dont, do you rerun all tests on the merged commit?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes, we rerun on merge
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so not quite what you say i guess
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the key for us is to reuse the image on deploy to production
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but not necessarily for all other steps
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yep, that part I have “pinned” i was wondering about the ohter part
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have a pipeline step to promote images and helm charts to production registry
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
We have basically 2 “stable” branches
- stage (staging/preprod)
- master (prod)
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
and I wanted to reuse the artifact from the PR to staging, to save some more time
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
gotcha - yea, we don’t have any thing for that. we also tend to do squash+merge, so the commit sha wouldn’t be the same
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yep, you dont even get a parent commit that way do you?
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
TBH, the core of the issue is not even on the pipeline, but mostly that some steps are just too slow (thanks Java/SBT dependancies)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, i can see why you’d want to do that
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
So to clean up:
- feature/xyz -> staging (PR): build,test
- staging (commit from merge): build, test, release, deploy
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Is that your workflow?
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
(maybe you do direct to master and use tags or some other CD workflow for prod)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
feature/1234/xyz
-> staging (pr), build image, run compose integration tests, push image to registry, deploy helm chart to pr-namespace in kubernetes cluster (e.g. pr-1234)master
(squash merge): build, test, release, deploy- tag release - build, test, release, deploy to preproduction
- production deploy - promote artifacts to production, deploy
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
honestly, every customer engagement is slightly different
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but it’s more or less like that
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah, indeed, im just trying to get some ideas
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
and most of the examples from “blogs” are simple stuff that would not work/fly in production
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea… i can show you some examples if you want to zoom sometime
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what are you using for cicd? are you deploying to kubernetes?
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
We are still on ECS, looking at EKS right now as we reached that point were ECS is just… annoying and we have enough people to support an EKS
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
At the moment? Travis, but forget about it as we are migrating to either GitlabCI or Buildkite before EoY hopefully, as we as well outgrew travis
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What I don’t like about GitLabCI is it only supports one pipeline per repo (last i checked)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have you looked at Codefresh?
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah, tbh im right now leaning to BuildKite as you can even dynamically load “pipeline”
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I did, but found it a bit less flexible
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Maybe I just did not understood it completly
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
dynamically load pipeline? what’s that?
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Lets say you have a pipeline like:
- build:
- run x
- if build == commit:
- loadpipeline pecigonzalo/this/.pipeline.yml
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
let me find the docs
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
data:image/s3,"s3://crabby-images/c22b5/c22b557b308d8abeda665b56ba0849cca3934108" alt="attachment image"
Automate your team’s software development processes, from testing through to delivery, no matter the language, environment or toolchain.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
and also, seamless triggers: https://buildkite.com/docs/pipelines/trigger-step
data:image/s3,"s3://crabby-images/c22b5/c22b557b308d8abeda665b56ba0849cca3934108" alt="attachment image"
Automate your team’s software development processes, from testing through to delivery, no matter the language, environment or toolchain.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In many things is like a nice buildbot (https://buildbot.net/) but pre done
Buildbot - The Continuous Integration Framework
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Now, this is not an easy challenge as its “hard” to identify the built artifact
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
since we enforce “up to date branches” im testing using git rev-parse --short HEAD^2
on the merge|commit
job to identify the artifact by the tag (we tag with the commit) of the branch that did the PR that was merged and created that commit.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
* 2341145 (HEAD -> master, tag: 0.2.1, origin/master, workingset) Merge pull request #15 from thithat/staging
|\
| * d1bd417 Merge pull request #14 from thithat/feature/this-that
| |\
| | * 43ba953 (feature/this-that) Test Version Flow release
* | | 16c043a Merge pull request #13 from thithat/staging
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
❯ git rev-parse --short HEAD^2
d1bd417
❯ git rev-parse --short HEAD^1
16c043a
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
thoughts? ideas? what is your current CI workflow? What do you build on PR and on merge?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so our workflow is slightly different
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have “unlimited staging environments” which correspond to PRs - one per PR; those just build images pinned to 0.0.0-gitsha
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
entire environments or just images?
2018-11-07
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In a similar tone to my previous question, anyone has a working workflow for using terraform plan from PR build or similar? Because while its the recommended way for terraform, I have yet to see a working workflow for it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think the “interactive pull requests” model is ideally suited for terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the slides linked below show a number of companies (recognizable brands) who use atlantis
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
our fork of atlantis addresses the immediate shortcomings until they are fixed upstream
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pecigonzalo if you are asking about how to trigger terraform plan/apply
from an open PR, we recently used atlantis
for a GitOps workflow. See #atlantis channel. Also @Erik Osterman (Cloud Posse) recently held a meetup during #connectweek in Pasadena (CA) where he gave a live demo using Atlantis with Terraform to provision AWS user accounts using only Pull Requests
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/aa88d/aa88df82f96f409ba3bbea95a22014f7460d6628" alt="attachment image"
This group is targeted to those interested in cloud automation & management, with a specific emphasis on Kubernetes/Docker, Helm, Prometheus, CI/CD, Microservices, etc. All skill levels are welcome. I
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/09dc9/09dc94dcc11b76ae63f53a7dcc0b4b72471f7c79" alt="attachment image"
GitOps is where everything, including infrastructure, is maintained in Git and controlled via a combination of Pull Requests and CI/CD pipelines. Reduce the learning curve for new devs by providing a familiar, repeatable process. Use Code Reviews to catch bugs and increase operational competency. Pr
2018-11-08
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
No, not exactly like that, im not a big fan of what atlantis does
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
It applies before merge, to me that is anti-pattern
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Except for terraform plans are poor
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I was thinking appling the plan
generated on PR, on the merge
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
They are optimistic at best
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So if you merge and apply now what is in git is not deployed
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If others are developing against it, they are just as blocked
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So what we’ve reconciled is auto merge on successful apply
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Well, but that is the same case for a CD container release
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
But for container releases it’s more stable
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You have more under your control
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"
Most terraform failures in my experience are due to bad values
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Containers get their values at runtime
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Not at compile time (not generally but ideally)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You can achieve what you want easily with Codefresh.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah, that is true, and a fair point, but not this one:
So if you merge and apply now what is in git is not deployed
If others are developing against it, they are just as blocked
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In theory in the container you have the same “posibility” of failure
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
but I agree, is not as likely, as easiert to caught on test
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
TF has a lot of sideeffect failure scenarios, that plan
does not catch
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
To me atlantis is a practical approach
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Not the theoretical ideal
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So rather than clutter the master commit history with a bunch of patch releases, rather get it in clean. We preserve a full transcript in the git comments so we have a record of what is deployed.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Even if the PR is closed but half applied, there’s a record of that’s
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah, its not a bad approach and im not saying Atlantis sucks, much the contrary, even Hashi bought them
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I just feel that is a “hack” around a bigger issue
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
a great hack, but a hack anyway
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Agreed
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In my previous company we had a rake
looper to get around TF Modules not having count
, it worked, and it saved us a lot of time, but in “terraform” it was a hack
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea I have heard of similar hacks… basically around code generation
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Slippery slope
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think within a closed ecosystem of a corporate environment that might fly, but it makes it very difficult to write portable code for open source
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Let’s orchestrate Terraform configuration files with Ansible! Terrible! - antonbabenko/terrible
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah indeed, im not so keen on it anymore. Good thing TF 0.12 is around the corner . This was a long time ago
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I wouldn’t touch 0.12 for a while…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I just don’t see a way around it that’s practical to solve (unless your HashiCorp and have 100mil in fresh green)
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah true
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I might give it 2nd chance, at least it will avoid those fix PRs for a stupid terraform value problem
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
BTW, its great to have a place to ping-pong this ideas
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea totally!! That what this place is for
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yep, thanks !
2018-11-10
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Run a plan, push an artefact, namely the plan output. Run an apply of said build artefact number. This could be a gitsha, PR number, Jenkins build number. I don’t see a huge advantage of Atlantis… although I caveat with not having used so opinions maybe wrong. Have been doing CI/CD of terraform plan + apply for a long time in Jenkins. Not a massive fan of having output in the PR for history. Your git history lives forever, github PRs may not. Running pre merge isnt ideal for team scenario’s. Have seen a lot of failed apply due to vars, state, lots of TF bugs, race conditions…
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Things like tflint can help with some of these
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
E.g. checking a type of AMI is even available in a region
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Won’t catch bugs though.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Is Atlantis just like serverless Jenkins ci/cd for terraform with output posted back to the PR?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Sounds nice if you don’t already have a CI/CD solution/don’t need one for other things?
2018-11-11
data:image/s3,"s3://crabby-images/f9282/f92823dfbdaa041adcec9bcb9a6365b6f2b836a8" alt="yurchenko avatar"
ok
2018-11-29
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
anyone here use github actions yet? do you know if there is a way to cache dependencies between builds?
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
haven’t seen anything in the docs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
no one @cloudposse has been invited to the beta
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i reached out to some peeps at GitHub but we don’t have the klout =0
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Gabe are you in the beta?
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
yeah we just got accepted in
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
just checked my inbox
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
nothing yet
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
i don’t think i got an email… just saw the new actions button on our repo
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
I got the email after the actions button appeared
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
ohh… they are also only available on private repos
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ohhhhhhhhh snap
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yep only private
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
hmm yeah… it looks pretty cool so far but a few things i’ve noticed is not being able to cache dependencies between builds, no control over the size of the machine it runs on (1 cpu 3.75 gb), and only two concurrent workflows running at one time per repo
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
pros are that it seems simpler than circle/jenkins and you can create actions that take environment variables so it’s easier to reuse/share actions between repos
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
… and we just got the email saying they have enabled it for us
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i just got the same email a few minutes ago, and Actions on my personal GitHub account
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
I’m not so lucky. Still waiting
2018-11-30
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@Andriy Knysh (Cloud Posse) this screenshot from https://github.com/cloudposse/github-status-updater how do you release to a namespace?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
every PR is a new k8s namespace. It’s how we do unlimited staging environments
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Thanks!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
see @Erik Osterman (Cloud Posse) presentation https://cloudposse.com/devops/unlimited-staging-environments/
data:image/s3,"s3://crabby-images/d9b3e/d9b3ef15dd1e5f9cd29f1c3cb3a793eb17a7b128" alt="attachment image"
How to run complete, disposable apps on Kubernetes for Staging and Development What if you could rapidly spin up new environments in a matter of minutes entirely from scratch, triggered simply by the push of a button or automatically for every Pull Request or Branch. Would that be cool? That’s
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@davidvasandani if you have questions or need more info, we can provide it
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@Andriy Knysh (Cloud Posse) do you happen to have an example where all these pieces are glued together?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@davidvasandani here’s a simpler and complete working example:
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what Add helmfile for deployment with monochart Add codefresh build manifest why Easy deployment to kubernetes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I use it for my demos
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
basically I took a random app called statup
(self-hosted statuspage.io clone) and deploy it on kubernetes using our monochart
with helmfile
and helm
using codefresh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this supports unlimited staging environments
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and automatic destruction when the PR is closed using the pull-request-closed.yaml
pipeline
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Thanks @Erik Osterman (Cloud Posse) can’t wait to dig into this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Crap I realized you need to know all the ENV
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@davidvasandani if you PM me I can get them to you
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
give me a few minutes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
re: Self-hosted Helm Chart Registry - Codefresh added Managed Helm Repositories after the presentation, so we use it now instead of deploying our own chart museum
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"
@davidvasandani ^