#release-engineering (2019-11)
All things CI/CD. Specific emphasis on Codefresh and CodeBuild with CodePipeline.
CI/CD Discussions
Archive: https://archive.sweetops.com/release-engineering/
2019-11-04
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
A GitHub action to create a pull request for changes to your repository in the actions workspace. - peter-evans/create-pull-request
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Very cool GitHub action
2019-11-05
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Need a suggestion : We are hosting a React website on S3, deployed through Jenkins. We have a story to set the site’s environment variables at deployment time (e.g. APIs URL, Vertex Cloud Auth Server , Redirection URL, etc.) but wanted to ping you guys to see if you are doing something like this today
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
we’re using AWS SSM Parameters – we use a multi-account strategy so each environment: DEV, TEST, PROD is a separate account with their own SSM parameters (keys are the same, values are different). My build process pulls the run time environment variables from SSM param store. for local dev, the team uses a .env
file with default values.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea, so a long these lines you’re basically going to want to do text replacement on the generated react site
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
tools like gomplate
or envsubst
are what we would use
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
whatever you upload to S3 needs to be static and cannot use envs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so you’ll need to use the envs as part of the CD process
data:image/s3,"s3://crabby-images/77a3a/77a3a57d6ce906de4836c91ecd24069207e79cb4" alt="vitaly.markov avatar"
We use the webpack plugin to setup env variables during build stage on CI (https://www.npmjs.com/package/dotenv-webpack) and as described above you can pull variables from AWS SSM or just put your variables to .env.development
, .env.staging
, .env.production
and keep in git, cause these variables should not contain sensitive data
A simple webpack plugin to support dotenv.
data:image/s3,"s3://crabby-images/77a3a/77a3a57d6ce906de4836c91ecd24069207e79cb4" alt="vitaly.markov avatar"
otherwise VueJs use the following convention https://cli.vuejs.org/guide/mode-and-env.html
Standard Tooling for Vue.js Development
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That sounds even better
2019-11-06
data:image/s3,"s3://crabby-images/12898/1289832d048e3f8693525fd2cfedde70e32d1629" alt="MattyB avatar"
Anyone have trouble finding the line with abstraction in Jenkins pipeline libs? I forked someone’s codebase at worked and played around with it. While it works, you have to drudge through documentation that’s formatted for github which is terrible compared to typical code documentation. You (or someone) end up trying to write reusable code but end up with a bunch of one-offs (multiple docker run stages). You’re forced to figure out all the variables that are set by hoping the person that wrote the documentation didn’t miss anything, so you end up looking through the code to verify. I think with my current project I’m going to leave most of the logic in our pipeline.yaml and let it tell the story of how our build works instead of the Jenkinsfile. I’m pretty sure I could write a book about it or find someone else that’s already gone through my grief. Just venting a bit too
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@MattyB today at #office-hours I want to ask more about people’s experience with Jenkins and #kubernetes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Join us if free!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
My motivation is we are starting a Jenkins project next week.
data:image/s3,"s3://crabby-images/12898/1289832d048e3f8693525fd2cfedde70e32d1629" alt="MattyB avatar"
data:image/s3,"s3://crabby-images/0acb4/0acb44db988a214b8e198fe6942a734ac2a097ee" alt="s2504s avatar"
That is great @Erik Osterman (Cloud Posse) Jenkins is a swiss knife in the CI/CD world and it must be in SweetOps team’s backpack
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha, yea, it was and then it wasn’t it’s a love/hate relationship.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but seeing as how many companies still use it, I totally agree!
data:image/s3,"s3://crabby-images/0acb4/0acb44db988a214b8e198fe6942a734ac2a097ee" alt="s2504s avatar"
yea, but in most cases Jenkins is very redundant for usual operations - build couple images and push them to registry. For this purpose I choose “free” CI tools linke Drone, GitlabCI and etc. Or if we need self managed solution - GitLab CI
data:image/s3,"s3://crabby-images/0acb4/0acb44db988a214b8e198fe6942a734ac2a097ee" alt="s2504s avatar"
But if we need some advanced logic in or pipelines - Jenkins is that we need
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Updated our alpine packages repo: https://github.com/cloudposse/packages/tree/master/.github/workflows
Cloud Posse installer and distribution of native apps, binaries and alpine packages - cloudposse/packages
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
- auto update packages (open a PR every night)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
- auto label PR with each package updated (great for mono repos)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
- auto clean up branches on merge
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
- auto assign PR for review
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(all github actions)
2019-11-13
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
anyone else trying mergify? started using it to auto-approve/merge prs that dependabot creates, with conditions that the required status checks pass… https://doc.mergify.io/
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
pull_request_rules:
- name: auto-approve dependabot pull requests
conditions:
- author~=dependabot\[bot\]|dependabot-preview\[bot\]
- status-success=continuous-integration/appveyor/pr
- status-success=continuous-integration/travis-ci/pr
actions:
review:
type: APPROVE
- name: auto-merge dependabot pull requests
conditions:
- author~=dependabot\[bot\]|dependabot-preview\[bot\]
- "#approved-reviews-by>=1"
actions:
merge:
method: merge
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
certainly some overlap in what it does and github actions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
No, but have somethings bookmarked to achieve the same thing with actions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Want to use actions :-)
2019-11-14
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
data:image/s3,"s3://crabby-images/2ed51/2ed51be2b3249795edbcc34a1c2caeb54b78aad0" alt="attachment image"
Today Weaveworks announces a partnership with Intuit to create Argo Flux, a major open source project to drive GitOps application delivery for Kubernetes via an industry-wide community. Argo Flux combines the Argo CD project led by Intuit with the Flux CD project driven by Weaveworks.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
super, waiting to see what they will have in the end
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
yeh - i’m getting a bit annoyed at the “we’re going to work on a thing” announcements
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
it’s becoming common
2019-11-19
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I was going to try , https://github.com/cloudposse/terraform-aws-ecs-atlantis, is there anything I should know about using this repo?
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we want to run atlantis in ECS
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We assume you BYO Docker container
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We use geodesic
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
BYO= ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
build your own ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Bring your own
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
or I can use the one in docker registry?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Perhaps but untested
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We have a more opinionated approach where by we deploy Atlantis in each AWS account we want to manage
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
And have a one to one correlation between AWS accounts and GitHub repos
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This ensures webhooks and repos and accounts are all aligned
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
well we want the same
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
each account with it’s own atlantis
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"
Give it a shot
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but you have multiples repos per account
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We have one repo per account
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also have you ruled out terraform cloud?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It’s a bit more polished
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we just the demo with hashicorp
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
to be honest I do not know if is such a huge advantage now that you have github actions self hosted runners
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
then we limit the UIs to just github
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and PR that is how we work usually
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so having a nice UI is not a huge win for Us
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
to be honest I was pretty dissapointed about the demo
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and workspaces can’t assume roles
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so it means that each workspace is one AWS account with aws key/secret in the settings
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
not so clear is those setting can be set trough the API
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and one workspace is one repo so if we use 5 repos per account it means we need 5 workspaces all with the keys duplicated
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so if you add key rotation to add it becomes pretty redious
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and they are not FIPS compliant
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so if they get hacked I gess you could get pretty F…..
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I guess
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Join us for #office-hours if you get stuck
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have a strip-down version of the ecs-web-app module that we use for all ECS related tasks
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is very similar to what is on that repo
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but this
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is kinda weird
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you are only allowing https/http and 53 out from atlantis ?
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Have anyone try https://www.gocd.org/ ?
data:image/s3,"s3://crabby-images/e3464/e3464aa059c44d5bb1697e30a0f67a214eb67ab5" alt="attachment image"
GoCD is an open source build and release tool from ThoughtWorks. GoCD supports modern infrastructure and helps enterprise businesses get software delivered faster, safer, and more reliably.
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
I used it at a past job a year or two ago running in a windows shop and not containers or anything
data:image/s3,"s3://crabby-images/e3464/e3464aa059c44d5bb1697e30a0f67a214eb67ab5" alt="attachment image"
GoCD is an open source build and release tool from ThoughtWorks. GoCD supports modern infrastructure and helps enterprise businesses get software delivered faster, safer, and more reliably.
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
Any specific questions?
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
@Alex Siegman not yet. Would be when I will make my hand dirty
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
I think the most difficulty I had is we didn’t use the various stages and pipelines and environments in the way gocd designed. Their organization of those things are a bit weird. I’d have to look again to remember the specifics, but overall it was easy enough to use as anything else like Jenkins, etc.
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
@Alex Siegman thanks. That is very useful
2019-11-20
2019-11-21
2019-11-25
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
CircleCi seems to be having outages on weekly basis. Is this common for other CI/CD platforms?
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
Never used to happen. Haven’t used it much in the last year. Suspect they may be going through some growing pains
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
We’ve been pretty happy with BuildKite
2019-11-26
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I’m very happy with Codefresh, when their macOS supports comes out of beta I’m planning to move our react native app over and shutdown our CircleCI account.
data:image/s3,"s3://crabby-images/ea4b2/ea4b2f632e46306eff36ebaf81856e464339346c" alt="amelia.graycen avatar"
I don’t suppose anybody has gotten these Jenkins automated upgrades working with the Docker image? We have them in our current version, but I’m looking in to moving Jenkins off of Windows and want to make sure we keep the feature.
data:image/s3,"s3://crabby-images/ea4b2/ea4b2f632e46306eff36ebaf81856e464339346c" alt="amelia.graycen avatar"
I wouldn’t be shocked if I were misinterpreting this document to some extent.
2019-11-29
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
for anyone who has used github actions, if I was to create a git action that had
on:
push:
branches:
- master
would you think this runs when a PR is merged to master?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I basically want to run a workflow when master has a change
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
You can test it by creating a PR to a dummy branch.
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
But yeah, it will run when a PR is merged to master