#codefresh (2019-01)
Archive: https://archive.sweetops.com/codefresh/
2019-01-03
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
CLI can now use your local machine as the volume for more verbose debugging.
--local-volume --lv Use your file system as volume in local run
data:image/s3,"s3://crabby-images/6011a/6011a623bc49207a322b7b17a894fa24a1aa02c6" alt="fiesta_parrot"
2019-01-07
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
Wondering if anyone solved/hit these:
1) discarding concurrent builds - imagine I want to have pipeline triggered on git commit, it takes 1 hour to run, but if any other build of the pipeline is triggered we only keep the currently building one and the most recent one, all others are discarded.
2) pausing pipeline - if we have pipeline triggered on commit or on cron - is there a way to manually pause the schedule? (other than deleting the trigger? since deleting/re-creating trigger is involved). Looking for something similar to Jenkins enable/disable pipeline button
3) what do people use for sequential/unique build numbering - if we wanted to generate semantic versions for our builds?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i’ve wanted to have “locks”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we can have a pipeline block untili it obtains the lock.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i’ve seen semver services
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g. you can curl an API for a given service and specify if you want a new path, minor or major release
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g. curl <https://semver.host.io?service=foobar&patch+=1>
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
interesting… not exactly what I wanted but makes sense
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
one of our problems is with helm versioning
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
basically different projects have pinned to different versions of our release harness
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
which mean different versions of helm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
one option is to always check the server and then use that version locally
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
on an totally unrelated note, I was surprised to see how many people we’ve found who like make
2019-01-08
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
make is the new hotness, until you get too deep into it. Is it a really cool project these days if it isn’t go & make ?
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"
yea, stay on the surface
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the deep waters of make are dangerous
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Likely not useful, but wrote https://github.com/joshmyers/dynolocker for a quick distributed lock before
A CLI tool for distributed locks using DynamoDB. Contribute to joshmyers/dynolocker development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh that’s cool!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, that’s basically what I wanted
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2019-01-09
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dustinvb have you seen #kubecost? I think this could add some extra bling to your demos.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
They have a dashboard that shows exactly how much a deployment costs plus makes it easy to “right size” pods.
2019-01-10
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Bah that link requires login LOL.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Have you seen the new metrics tab on the bottom of your builds we pushed yesterday?
The main one shows cumulative and you can also see each step there or click on the step and get more details.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
The stats are just so freaking awesome!!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I did see them the other day
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That link is just medium being medium. There’s a X in the upper right corner that closes at dialog. Stupid medium.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Also our first version of our behind the firewall agent has been released. https://github.com/codefresh-io/venona You can deploy to your Kubernetes cluster and use as a custom runtime.
Codefresh runtime-environment agent. Contribute to codefresh-io/venona development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/a9fa6/a9fa6c642c2cffbe20ec9a71522b08dac940c5da" alt="party_parrot"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Dustin how is that different from using the codefresh cli deploy the run time environment?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
That requires you allow ingress from Codefresh SaaS
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
This would be where you don’t want to expose your Kubernetes API to internet.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That’s badass
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Sorry API proxy is coming soon. This allows for the runtime to be behind the firewall in our Hybrid scenario.
2019-01-17
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"
we’ve released our helmfile to install the codefresh
runtime environment using our monochart
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Comprehensive Distribution of Helmfiles. Works with helmfile.d
- cloudposse/helmfiles
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dustinvb
Comprehensive Distribution of Helmfiles. Works with helmfile.d
- cloudposse/helmfiles
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@mumoshu has joined the channel
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
We also have venona now which does behind the firewall runtimes with no ingress.
Codefresh runtime-environment agent. Contribute to codefresh-io/venona development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Cool, we will do the same for that
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
The manual approval, step is due out next week. You’ll already see in Slack there is an option to send notifications about approval builds and a new option on the build screen to the right of pending for builds waiting approval.
data:image/s3,"s3://crabby-images/91017/910177adba94615aa40428c968883b16f580e2bd" alt="1000"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That will be awesome!!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So an engineer can kick off the deployment by cutting a release in github
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that triggers a codefresh pipeline
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
which requests an approval via slack to the engineering manager
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if he approves it, then the deployment proceeds.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yes but permissions are not available yet around the process but the pipeline is stamped with the user who approved/denied.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Ah I see you, didn’t say you joined.
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
Clearly, I am a ninja
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
2019-01-18
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is awesome!
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"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
not sure if you guys have investigated how Travis does their remote exec
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but it’s via tmate
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I’ve reproduced the functionality with this code snippet
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 assumes tmate
binary is in your path
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if you run this snippet, you will get this output
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
I haven’t personally nor heard of anything about this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ssh [email protected]
ssh [email protected]
<https://tmate.io/t/z0Kgk9o3hU8e6pRYE4fU008mc>
<https://tmate.io/t/ro-XGFBNsGrPrVg4vKdPS5xrjW4k>
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then I can exec into the container
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so how does this relate to codefresh?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
You should tell me.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
LOL
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so if a container step you add sleep inf
, that step won’t finish
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if the step before that runs the script I shared, then it starts a reverse tunnel out to [tmate.io](http://tmate.io)
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Codefresh is a Docker-native CI/CD platform. Instantly build , test and deploy Docker images.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then I can effectively debug my codefresh container running on codefresh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok, this is cool
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
We need to think about this as another option and see about a new Fresh Step
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s cool!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i didn’t know about the composition terminal
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
though that won’t apply to pipelines, right?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
general pipelines
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so travis has a button that basically says, on next run, start a tmate session
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i think in the codefresh world, it would almost be like setting a break point
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
only that the container is left running
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@michal.matyjek @Daren what do you think about something like this?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
not sure if you guys have investigated how Travis does their remote exec
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
provided a hack above
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
would be awesome to have this built-in otherwise everytime we want to debug we need to modify a step (or inject it into all steps?)
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
wtf is my profile…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, built-in best
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
(or make running locally easy - like a button in the Codefresh UI to run the piepeline/step locally with breakpoint so that you can exec into the container)
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
I think the break point feature in the UI would be great to read it from yaml or be able to click a step in the UI to set a break point during execution.
A FreshStep though might should be a faster to market MVP.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
HOLY MOLY! I have brilliant idea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I’m going to add tmate/session
as a target in our build-harness
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then just add make tmate/session
in any pipeline step for debugging
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and it will output a temporary session
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in the build logs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it will block indefinitely until the tmate
session exits or a preconfigurable timeout
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@daveyu
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
I’ve invited Francisco here from my team. I think this debugging utility talk will interest him.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
We just ran into something today this would have aided in. I’d like to get this integrated into the pipeline like we do with cf_export.
data:image/s3,"s3://crabby-images/73f7a/73f7a9b16d513365921c22ac714c01731e99e48b" alt="daveyu avatar"
This kind of feature was really useful when I used CircleCi
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2019-01-20
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Codefresh in on thoughtworks’ tech radar
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
data:image/s3,"s3://crabby-images/ff135/ff1359296cf9b6e7cdf67fedd6fec19737d6b408" alt="attachment image"
The Technology Radar quadrant that explores the latest tech trends in the tools software developers use to create, debug, maintain, and support applications
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
nice!
2019-01-23
data:image/s3,"s3://crabby-images/73f7a/73f7a9b16d513365921c22ac714c01731e99e48b" alt="daveyu avatar"
I’m trying to deploy to a new k8s cluster, and thinking I missed a step somewhere when provisioning it. any clues here? yaml:
title: Deploy with helmfile
stage: Deploy
image: 'cloudposse/build-harness:${{BUILD_HARNESS_VERSION}}'
working_directory: ./
environment:
- 'IMAGE_TAG=${{SEMVERSION_COMMIT_SHORT}}'
- 'RELEASE_NAME=${{NAMESPACE}}'
- APP_API_ROOT=https://${{BACKEND_APP_HOST}}'
- 'AWS_ACCESS_KEY_ID=${{CHAMBER_ACCESS_KEY_ID}}'
- 'AWS_SECRET_ACCESS_KEY=${{CHAMBER_SECRET_ACCESS_KEY}}'
commands:
- make helm/toolbox/upsert
- chamber exec app -- helmfile sync
log output:
Pulling image cloudposse/build-harness:0.15.3
Digest: sha256:48379abbffe7707ce8185839c24ad20830e45fec7092edbf4febf6b2e859df98
Status: Image is up to date for cloudposse/build-harness:0.15.3
ERROR: kubectl not installed!
make: *** [//build-harness/modules/helm/Makefile:24: helm/toolbox/upsert] Error 1
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that looksl ike a really old version of the build-harness
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
newer versions ship kubectl
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh snap
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"
I can take a look in a few hours
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
about to give a demo of this https://github.com/cloudposse/example-app
Example application for CI/CD demonstrations of Codefresh - cloudposse/example-app
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Blue/Green deployments with Codefresh and Istio and Helm
data:image/s3,"s3://crabby-images/73f7a/73f7a9b16d513365921c22ac714c01731e99e48b" alt="daveyu avatar"
cool. i’ll poke around.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it uses our “cartrige” style deployment methodology where everything is bundled in the deployment artifact (aka docker image)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
to get unblocked, you should be able to do:
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
make packages/install/kubectl
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
as a build step
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@daveyu i think it should be a geodesic
image
image: cloudposse/geodesic:${{GEODESIC_VERSION}}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Though if he does that, then he needs to install the build-harness
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so it’s neither here nor there
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
split into two steps
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, could possibly do that
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
deploy_helmfile:
title: Deploy with helmfile
stage: "Deploy"
image: cloudposse/geodesic:${{GEODESIC_VERSION}}
environment:
- AWS_REGION=us-west-2
commands:
# Install or upgrade tiller
- "make init"
- "make helm/toolbox/upsert"
# Deploy chart to cluster using helmfile
- "chamber exec kops -- helmfile --file config/helmfile.yaml --selector component=app sync --concurrency 1 --args '--wait --timeout=600 --force --reset-values'"
# Add kiam annotation
- kubectl annotate namespace ${NAMESPACE} "iam.amazonaws.com/permitted=.*" --overwrite
data:image/s3,"s3://crabby-images/73f7a/73f7a9b16d513365921c22ac714c01731e99e48b" alt="daveyu avatar"
thanks! i’ll try those options
data:image/s3,"s3://crabby-images/73f7a/73f7a9b16d513365921c22ac714c01731e99e48b" alt="daveyu avatar"
fyi this was the example i followed, and it did work before with the same build-harness version. https://github.com/cloudposse/statup/blob/add-helmfile/codefresh/pull-request.yml#L82
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That’s really odd. I can’t explain it.
2019-01-24
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
I am trying to deploy an application, with the image being pulled from cfr. I added a Secret to the helm chart so that the chart would deploy everything needed for the application, but it doesn’t create the secret first. What is the best practice for uploading the secret?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
good question.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so there are a few ways to handle this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If you’re not going to be using a lot of namespaces, it would be most secure to deploy the pull secret manually as a “one off”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If you’re using kops
, you can provision a cluster-wide pull secret
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If you’re using helmfile
, then you can deploy it by adding a release of this: https://github.com/cloudposse/charts/tree/master/incubator/dockercfg
The “Cloud Posse” Distribution of Kubernetes Applications - cloudposse/charts
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Mock deploy a secret using our Services page: https://codefresh.io/docs/docs/deploy-to-kubernetes/manage-kubernetes/#deploy-new-service
Use Codefresh CLI: https://codefresh-io.github.io/cli/more/image-pull-secret/
Codefresh is a Docker-native CI/CD platform. Instantly build , test and deploy Docker images.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
These work with any registries you have connected to Codefresh.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Maybe too many options?
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"
@dustinvb would be nice if there was a build-step or something we could use to automatically provision the pull secret for a namespace
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
You can use the CLI as a build step.
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
lol, this is all good stuff. So if I am going to have a namespace per dev team or developer, would it be best to have a helm chart that configures the namespace with all secrets needed?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the downside with provisioning secrets with helm
is that they are in clear text if you run helm get values
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and are also surfaced in clear text in the helm
UI in codefresh
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
thats good to know
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Bah I am all off on my explanation… I mis read what you’re trying to do.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Use helm-secrets plugin
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
That’s what I used
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the helm-secrets
plugin doesn’t fix it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the values are still passed in clear-text to helm
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yes they are indeed but on the Kubernetes side it will create the secret for you using the Helm Chart.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hrmm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
or do you mean helm-secrets
will create the Secrets
resource out-of-band with helm
, so that it won’t be visible by helm
?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
If you don’t want these secrets showing up in a pipeline it is best to circumvent the secret creation in CI/CD something else like https://github.com/Boostport/kubernetes-vault
Use Vault to store secrets for Kubernetes! Contribute to Boostport/kubernetes-vault development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
It is still visible by Helm Releases and the command in the pipeline.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dustinvb check this out: https://github.com/mumoshu/aws-secret-operator
A Kubernetes operator that automatically creates and updates Kubernetes secrets according to what are stored in AWS Secrets Manager. - mumoshu/aws-secret-operator
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@mumoshu wrote this! I can’t wait to use it. no need to deploy vault.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Nice!
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yeah for AWS this looks great. I don’t have enough access in AWS to create an example of this. If you ever have a pipeline with a helm chart using this I’d like to check it out.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
True… AWS solution.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Mark, do any of these options look viable for your use case?
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
I think for now just to get unblocked i might create manually. https://github.com/mumoshu/aws-secret-operator looks pretty cool in the long term though
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
Thanks you guys!
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
Anyone here used codefresh api to start pipelines? The swagger at codefresh.io/api is not very clear…. or FWIW - anyone integrated Spinnaker with Codefresh?
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
cc @Purva
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Our CLI is built off of the API. https://github.com/codefresh-io/cli/blob/master/lib/logic/api/pipeline.js#L116-L165
I’ll get your feedback to the team about the API.
Codefresh CLI. Contribute to codefresh-io/cli development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
1 vote and 0 comments so far on Reddit
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Could be useful if any codefresh customers are using terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Dan Garfield
data:image/s3,"s3://crabby-images/e353b/e353b66f4b779b900232cd21528541cb9e9f3399" alt="Dan Garfield avatar"
@Dan Garfield has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
A changelog of new features
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s some pretty sweeet feature velocity
2019-01-25
data:image/s3,"s3://crabby-images/8e770/8e77078db0aaf6350ec88a953039f0bf3069c75d" alt="Daren avatar"
Is it possible to trigger a pipeline via a webhook, and have the pipeline product an artifact that the caller has access to, say a json file
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ohhhh some artifact scoped to the CF_API_KEY
?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I don’t know the answer. If they did, it would probably related to this new feature: https://codefresh.io/docs/docs/testing/test-reports/
How to create and view Test reports in Codefresh
data:image/s3,"s3://crabby-images/8e770/8e77078db0aaf6350ec88a953039f0bf3069c75d" alt="Daren avatar"
@francisco said you can create a named context, then used a (currently) undocumented api call to obtain it. A cronjob pipeline can be used to clean them up
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
is the API call related to the test reports?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ohhhh i think i understand now
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you have a pipeline that writes an artifact to the shared volume
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and you want to know if you could read that artifact from that volume using the codefresh cli?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(and apparently this is possible using that undocumented call)
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Example of writing a file to context. https://github.com/codefresh-io/eks-installer/blob/master/scripts/codefresh-save-tfstate.sh
Tool to setup a new EKS cluster and connect to Codefresh - codefresh-io/eks-installer
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Using that at a later date https://github.com/codefresh-io/eks-installer/blob/master/scripts/codefresh-load-tfstate.sh
Tool to setup a new EKS cluster and connect to Codefresh - codefresh-io/eks-installer
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Oh this is cool
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Example API call to get this context from another system: https://github.com/codefresh-io/cli/blob/master/lib/logic/api/context.js#L50-L60
Codefresh CLI. Contribute to codefresh-io/cli development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Since you get the build id when you trigger a pipeline, I’d suggest setting that in the file name and then you’ll be able to have a unique per build file.
2019-01-28
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is awesome! https://steps.codefresh.io/
One small step for your YAML, one giant leap for your pipeline.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It would be cool if there was a way to define like a step.yaml
in a repo with sufficient annotations that codefresh could just populate this automatically.
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
I second that ^^^
2019-01-29
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
Anyone know how to nest an array in cfstep-helm value override? For reference I am trying to set the extraHostPathMounts for the kiam helm chart https://github.com/helm/charts/blob/master/stable/kiam/values.yaml#L182
Curated applications for Kubernetes. Contribute to helm/charts development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
I wound up creating a new repo with just a codefresh.yaml and a values file
Curated applications for Kubernetes. Contribute to helm/charts development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have you looked into helmfile
?
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
I hadn’t ever heard of it. Looking into it now
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Comprehensive Distribution of Helmfiles. Works with helmfile.d
- cloudposse/helmfiles
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So we use this both to distribute backing services as well as applications
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and by “applications” i mean those delivered via a codefresh pipeline (e.g. web apps)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
here’s our “example app”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Example application for CI/CD demonstrations of Codefresh - cloudposse/example-app
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the deploy/
folder contains the helm releases
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We use this exclusively with helm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
helmfile takes the pain out of dealing with values.yaml
and helm releases.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
plus makes it easier to make helm
more 12-factor compliant
2019-01-30
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Igor Rodionov @Maxim Mironenko (Cloud Posse) https://github.com/codefresh-contrib/cfstep-pipeline-creator
data:image/s3,"s3://crabby-images/bc38e/bc38e529d2aaa7d65a302b2c4f50b7316325cf1a" alt="Maxim Mironenko (Cloud Posse) avatar"
@Maxim Mironenko (Cloud Posse) has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
How does this compare to https://github.com/cloudposse/codefresh/tree/initial-implementation
Codefresh repos and pipelines in code. Contribute to cloudposse/codefresh development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We’ve updated our example-app
with our pipelines for unlimited staging, automatic destroy, release promotion, and multiple cluster deploys using tags
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Example application for CI/CD demonstrations of Codefresh - cloudposse/example-app
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This also has an example of blue/green deploy’s using Istio
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use helmfile
with helm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use variant
as a “deploy cli”
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"
what’s notable about these updated pipelines is we avoid the classic “main clone” in every pipeline other than build
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this makes it faster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the build artifact always contains the helmfile
to deploy. this is an evolution of our statup
demo (which is now out of date)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dustinvb I want to add now all the clair scanning and other kinds of tests
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
https://steps.codefresh.io/ should have the most up-to-date documentation some testing steps requires the user to work with vendor to install server side.
One small step for your YAML, one giant leap for your pipeline.
2019-01-31
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
smashing dashboard for Codefresh builds. Contribute to mkj28/smashing-codefresh development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
anyone wanting to improve this - forks are more than welcome
smashing dashboard for Codefresh builds. Contribute to mkj28/smashing-codefresh development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Nice for office wallboards!
data:image/s3,"s3://crabby-images/f2c82/f2c82bba04dbd146121250af6328052e7afa601f" alt="Oleg Sucharevich avatar"
Cool!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this is by @michal.matyjek
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Codefresh’s Status Page - 504s and Latency on Builds and Pipeline pages in UI.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
thanks for the heads up
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
thankfully at this very moment, not building.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Wonder if we can just integrate the status page into the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
done
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Incident reported earlier has been resolved.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Wierd, we didn’t get the all lear message from the atom feed?
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
504s and Latency on Builds and Pipeline pages in UI Jan 31, 20:14 UTC Resolved - The issue has been identified and resolved. It was due to a high load on the system. We scaled it up and took the corresponding actions to prevent further issues. Jan 31, 20:14 UTC Monitoring - We’ve resolved the issue and are actively monitoring the system. Jan 31, 19:02 UTC Investigating - Our Team is investigating reports with 504 Gateway errors and latency in Codefresh pages.
Codefresh’s Status Page - 504s and Latency on Builds and Pipeline pages in UI.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
That took a bit…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea, guess it doesn’t poll too often
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
GitHub Incident Jan 31, 22:11 UTC Resolved - GitHub has reported this incident as Resolved. More information here: https://www.githubstatus.com/ Jan 31, 22:10 UTC Update - We are continuing to work on a fix for this issue. Jan 31, 22:01 UTC Identified - GitHub has reported an ongoing incident. This could affect your builds. More information here: https://www.githubstatus.com/
Codefresh’s Status Page - GitHub Incident.
Welcome to GitHub’s home for real-time and historical data on system performance.