#release-engineering (2019-10)
All things CI/CD. Specific emphasis on Codefresh and CodeBuild with CodePipeline.
CI/CD Discussions
Archive: https://archive.sweetops.com/release-engineering/
2019-10-03
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
2019-10-08
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
does anyone here use the serverless framework? If so, do you have a CICD pipeline for it(looking for a way to do automated rollbacks upon failure, manual gates for going to prod etc)
data:image/s3,"s3://crabby-images/58038/58038b05d79ca7db6a1153a61ed5d38847b32b23" alt="Blaise Pabon avatar"
Do you know about openFAAS? https://www.openfaas.com/blog/openfaas-cloud-gitlab/
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We implemented this with Codefresh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We used approval steps for gates
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
And implemented unlimited staging environments
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) can share more
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Adam is one happy camper
data:image/s3,"s3://crabby-images/1a4b2/1a4b2bc19410d0f2cf7913ea0ff0cc7bf8a915a2" alt="Adam avatar"
@Adam has joined the channel
2019-10-16
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@Andriy Knysh (Cloud Posse) I’d love to hear more about this.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i understand this is in a private repo implemented for a customer. We need to discuss with @Adam how to share it
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@Brij S we use the serverless framework a lot and are also struggling with CI/CD. I’d love to hear what you’ve come up with so far and how you’re doing branching.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
as of now, the best ive got for you is to use github actions and codepipeline
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
its definitely not the best idea, but it ‘works’
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
I actually jotted down some notes on serverless and CICD, it’s on my list for an upcoming project coming from one of my dev teams. I’m not sure what part of CICD you’re struggling with, but I think it’s key to decide what resources live with what development lifecycle.
My notes aren’t really good for public consumption since it’s all shorthand, but, the general concept is that you should figure out the demarcation of what serverless manages, and what your other IaC manages. Then your CICD for serverless can become much easier, as it just pulls in dependencies through SSM, or CloudFormation exports, or any number of things.
Here’s a link talking about this by using cloudformation exports as an intermediary: https://theburningmonk.com/2019/03/making-terraform-and-serverless-framework-work-together/
data:image/s3,"s3://crabby-images/7dbec/7dbecedaffaf87150732d3a6224442c7b608dd7d" alt="attachment image"
The Serverless framework is the most popular deployment framework for serverless applications. It gives you a convenient abstraction over CloudFormation and some best practices out-of-the-box: Filters out dev dependencies for Node.js function. Update deployment packages to S3, which lets you work around the default 50MB limit on deployment packages. Enforces a consistent naming convention for … Making Terraform and Serverless framework work together Read More »
data:image/s3,"s3://crabby-images/58038/58038b05d79ca7db6a1153a61ed5d38847b32b23" alt="Blaise Pabon avatar"
data:image/s3,"s3://crabby-images/da939/da93982e2652f463ed4603645bc157eaa0513f49" alt="attachment image"
Learn how to provision your own OpenFaaS Cloud on Kubernetes connected to a self-hosted GitLab instance on any public or private cloud within 100 seconds.
2019-10-17
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
trying to wrap my head around releasing node apps vs semantic versioning (version change in package.json) and making it simple for developers. Couple ideas, but open for more:
1) with release
branch - release is merging from master to release, then use https://github.com/semantic-release/semantic-release to bump version, tag git, and package
2) when developer bumps version in package.json- detect that and release then? Any tooling for this style though?
data:image/s3,"s3://crabby-images/f0c8d/f0c8d50bdbac83e478759bbd7c5c46302c0c04a3" alt="jafow avatar"
Any tooling for this style though?
we do something similar and built some custom scripts that track all versions of apps in release with a manifest.
data:image/s3,"s3://crabby-images/f0c8d/f0c8d50bdbac83e478759bbd7c5c46302c0c04a3" alt="jafow avatar"
the release captain or lead is responsible for deciding if there’s a semver minor or major bump. the versioning script picks it up and updates
data:image/s3,"s3://crabby-images/f0c8d/f0c8d50bdbac83e478759bbd7c5c46302c0c04a3" alt="jafow avatar"
mostly i’m commenting here to get updates on this thread because i’d be interested in hearing more about this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Mostly agree with @jafow
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
One other thing I have seen and like is simply to define the release in the code. That way it can be reviewed. Using GitHub actions you can easily enforce that it is modified. Then on merge a release will be cut based on that file
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think developing a heuristic is difficult and mileage may vary
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This approach means that you get full control over the semver and easily enforced
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Couple this with CODEOWNERS and you also have a way to ensure release captains are involved
data:image/s3,"s3://crabby-images/f0c8d/f0c8d50bdbac83e478759bbd7c5c46302c0c04a3" alt="jafow avatar"
Hi @Erik Osterman (Cloud Posse)
like is simply to define the release in the code.
can you please say more about this? do you mean for example defining release in the code by adding a yaml file for your CICD that describes the build/rollout process? Or something else?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
No, basically, create a release.txt
file with the semver in it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
as part of the CI/CD process, upon a merge to master
, the pipeline cuts a release corresponding to the value in release.txt
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
or .release
or .github/RELEASE
something like that
data:image/s3,"s3://crabby-images/f0c8d/f0c8d50bdbac83e478759bbd7c5c46302c0c04a3" alt="jafow avatar"
ah yep I see thanks.
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
this is interesting workaround
surprised this is not a solved problem by now though… I spent some time googling over weekend and could not find anything ready-made for this
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
how do you check release.txt was modified ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
In the GitHub action, you would use something like this: https://github.com/nholden/modified-file-filter-action
Modified File Filter for GitHub Actions. Contribute to nholden/modified-file-filter-action development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you can check the list of modified files in the PR to ensure that one of the is the release.txt
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This looks pretty close: https://github.com/marketplace/actions/release-drafter
Drafts your next release notes as pull requests are merged into master
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Looks like it supports a .github/release-drafter.yml
file
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Because cutting a release actually has a lot more metadata than just the version
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
things like the body of the release
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
thanks
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
not a big fan of github actions though (or at least not yet)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
How come? What is lacking?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
With CircleCi, we can use either a merge or a specific tag to get a release going. It can do the version bump on its own so develop doesn’t have to think about it
2019-10-18
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Does anyone pay for Serverless Enterprise?
2019-10-20
2019-10-21
2019-10-22
2019-10-23
data:image/s3,"s3://crabby-images/2682a/2682a6560c5111355e1eb7e0f4dabea022f702a8" alt="shtrull avatar"
here is something that is starting to annoy me, maybe someone here knows about this problem and maybe knows how to fix it, I just started to learn and use Jenkins shared libraries, first loving it one place to make changes in all of my multi repo env my problem is that in every one of my builds I have pollSCM configured (mandatory), and every time I push a new change to my shared library master branch (which is configured in the Jenkins main config), every build I got starts to run if I make changes or add new things I have to wait sometimes 1 hour before the queue clears which is not good, Does anyone maybe know how to fix this problem??
2019-10-24
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
Only solution I’ve found is to not use pollSCM with Jenkinfile pulled from a separate repo. Options : use web hooks from code repo only or move Jenkinsfile to code repo. PollSCM triggers on any SCM reference in the job. When the Jenkinfile and shared libraries are not directly pulled from SCM by the job, they won’t trigger it
2019-10-30
data:image/s3,"s3://crabby-images/2682a/2682a6560c5111355e1eb7e0f4dabea022f702a8" alt="shtrull avatar"
after adding @Library(value="jenkins_shared_libraries", changelog=false) _
I managed to fix the problem