#codefresh (2019-04)
Archive: https://archive.sweetops.com/codefresh/
2019-04-01
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
So it turned out I was using ‘global variables’ and build variables wrong
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
I thought this would mean when I run the build
pipeline my Dockerfile’s ARG PORT
would get a value of 3060
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Turns out it doesn’t
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
So I found this: https://codefresh.io/docs/docs/yaml-examples/examples/build-an-image-with-build-arguments/
Codefresh is a Docker-native CI/CD platform. Instantly build , test and deploy Docker images.
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
and that’s fine.. happy to define it in a codefresh.yml file
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
but then I realised how do I do multi-branch / stage CI… surely I’ll need multiple codefresh.yml because one example argument is APP_ENV
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Did you try to use interpolations with:
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
build_arguments:
- key=value
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
build_arguments:
- APP_ENV=${{APP_ENV}}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also, what we do sometimes is create a reusable pipeline like build.yaml
that we call from something like some-app.yaml
; the some-app.yaml
can trigger the build
pipeline and pass settings to it.
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Ahhh I did not try interpolating. I went from not declaring args in .Yaml to declaring hardcoded and removing the vars from the console
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
I was going to have a pipeline for each stage inside the codefresh UI which runs off the same codefresh.yml and simply has the build args in the UI
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Does any of this sound like I’ve done / misunderstood it incorrectly, as having multiple codefresh.yml doesn’t feel DRY.. especially to only change a few build args. Thanks
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Ah.. unless it should be ENV
instead of ARG
idk
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
how many variables are you setting at build time? I usually just use environment variables that are set at run time instead of build time. I add the environment variables through the pod definition. This allows my Dockerfile to be pretty generic
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
So far 2. Vant see it breaching 5
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
I see your screenshot that your are setting aws secrets and the port for your container. I don’t think the port matters on your Docker container, so I am assuming its more about your aws secrets. I never was a fan of keeping keys lying around, and I liked having everything controlled through IAM. May I suggest taking a look at https://github.com/uswitch/kiam ? That’s what we use to make pods have specific IAM permissions, and it works great.
Integrate AWS IAM with Kubernetes. Contribute to uswitch/kiam development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Thanks Mark. I’ve actually removed it now. It was when I was trying put ECS
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
The two args I have are: application port and application env file.
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Because I then do:
COPY ${APP_ENV} .env
2019-04-02
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
How would you go about checking if .env
is a directory or file inside a docker image inside a pipeline?
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
You could have a freestyle step running a bash IF -f or -d; you could have some sort of condition in Dockerfile maybe?
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
And also to add geodesic to CI, good to just use https://github.com/cloudposse/prod.cloudposse.co/blob/master/codefresh.yml ?
Example Terraform/Kubernetes Reference Infrastructure for Cloud Posse Production Organization in AWS - cloudposse/prod.cloudposse.co
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Seems to be only pushing to codefresh registry which works for me. Unsure why it defines an old build harness?
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Erik, where’s an example of you executing a command in a geodesic module from a freestyle step in codefresh?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what Demonstrate how to do CI/CD of Terraform with Codefresh why Larger goal is to apply this to all reference architectures and terraform modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We should move that “use_codefresh” direnv function into geodesic
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
thanks
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
I get this funny bash script actually
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
DeployingDockerImage:
title: Deploying Docker Image with Ansible
image: r.cfcr.io/user/acme/${{MODULE}}.acme.co.uk:master
command:
- ansible --version
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@oscarsullivan_old that’s the default behavior of geodesic
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s why you can run
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
docker run myco/myinfra | bash
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
to install geodesic
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
to avoid that, do this:
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
what did I miss there Erik?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what Demonstrate how to do CI/CD of Terraform with Codefresh why Larger goal is to apply this to all reference architectures and terraform modules
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
because command
not cmd
?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cmd:
- "-l"
- "-c"
- "./tests/run.sh"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i am not sure about command
vs cmd
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Run commands inside a Docker container
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
looks like cmd
is canonical
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
ah I went from this
CollectAllMyDeps:
title: Install dependencies
image: python:3.6.4-alpine3.6
commands:
- pip install .
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Ok will try to make it closer looking to what you’ve got
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh, so yea, cmd
is the arg passe to the entrypoint
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
could be the difference
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
vs commands
is run after the entrypoint
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
ahhh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you can try this:
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
that makes sense
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
step_name:
title: Step Title
description: Step description
image: image/id
working_directory: ${{step_id}}
commands:
- bash-command1
- bash-command2
cmd:
- arg1
- arg2
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
although that confuses me again
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cmd: ["-l", "-c", "true"]
commands:
- "my command"
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
cmd: ["--version"]
commands:
- "ansible"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
no
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hrm… maybe
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
seems dull I can’t just have commands: ansible --version
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
and have to split it up
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
nono
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
I’ll give these new combos a go
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in that example, you are passing --version
to the entrypoint which is bash
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so you should get the version of bash back
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
ooh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you could alternatively change the entrypoint
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
study up on ENTRYPOINT
vs CMD
in docker
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then see what we’re doing in the Dockerfile
for geodesic
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
study […]
Thanks
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Must admit I don’t really get the differences
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Seen both in action but no further
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, the subtle nuances are often misunderstood by Dockerfile
authors
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and you see them misused and abused
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I liken it to the system call
int execve(const char *filename, char *const argv[],
char *const envp[]);
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ENTRYPOINT
~ filename
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
CMD
~ argv
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(this is my mental model, not the docker explanation)
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
lol Erik it was because I had command
not commands
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
DeployingDockerImage:
title: Deploying Docker Image with Ansible
image: r.cfcr.io/xxx/xxx/${{MODULE}}.xxxx.co.uk:master
commands:
- ansible --version
# ansible-playbook pod.yml -i inventory/${{inventory}}.yml
Output:
Status: Downloaded newer image for r.cfcr.io/xxx/xxx/sandbox.xxx.co.uk:master
ansible 2.7.9
config file = None
configured module search path = [u'/conf/.ansible/plugins/modules', u'/usr/share/ansible/plugins/modules']
ansible python module location = /usr/lib/python2.7/site-packages/ansible
executable location = /usr/bin/ansible
python version = 2.7.15 (default, Jan 24 2019, 16:32:39) [GCC 8.2.0]
Reading environment variable exporting file contents.
Successfully ran freestyle step: Deploying Docker Image with Ansible
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Now I gotta get my private Role + Playbook accessible
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Thinking either have them in conf, have some kind of wget situation and publicise them (not ideal), try and do an import like with terraform modules?????
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Our strategy for this is to write the key to chamber
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
However, I think for your purposes, it might be sufficient to write the key to a codefresh secret
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You can easily add an SSH key to the agent using an environment variable
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
source <(ssh-agent -s)
ssh-add - <<<${ANSIBLE_SSH_PRIVATE_KEY}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Geodesic is a cloud automation shell. It's the fastest way to get up and running with a rock solid, production grade cloud platform built on top of strictly Open Source tools. ★ this repo! h…
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Or my geodesic module has a git clone.. but then where do I store the deploy key hmmmm
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Have come up with this solution
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You could also clone as a step in the codefresh pipeline
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that would be accessible from inside of geodesic
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the benefit of doing it that way is that you can leverage the git integrations already available in codefresh without putting a secret (e.g. /conf/ssh/deployment-repo-key
into git)
2019-04-03
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Oh wow
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
yeh you’re right
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
that’s perfect actually. thanks
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Webhooks issue Apr 3, 09:27 UTC Resolved - The incident been resolved Apr 3, 09:24 UTC Investigating - We are currently investigating an issue where git webhooks don’t trigger pipelines. Running builds manually works as expected
Codefresh’s Status Page - Webhooks issue.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Codefresh availability issue Apr 3, 12:29 UTC Investigating - We are currently investigating a problem affecting Codefresh availability
Codefresh’s Status Page - Codefresh availability issue.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Codefresh availability issue Apr 3, 12:46 UTC Monitoring - Codefresh site is up, we’re still monitoring the system Apr 3, 12:29 UTC Investigating - We are currently investigating a problem affecting Codefresh availability
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Codefresh availability issue Apr 3, 13:34 UTC Update - Google just updated us on an ongoing incident, we’re monitoring the issue with google team Apr 3, 12:46 UTC Monitoring - Codefresh site is up, we’re still monitoring the system Apr 3, 12:29 UTC Investigating - We are currently investigating a problem affecting Codefresh availability
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Codefresh availability issue Apr 3, 14:23 UTC Resolved - This incident has been resolved. Apr 3, 14:22 UTC Update - We are continuing to monitor for any further issues. Apr 3, 13:34 UTC Update - Google just updated us on an ongoing incident, we’re monitoring the issue with google team Apr 3, 12:46 UTC Monitoring - Codefresh site is up, we’re still monitoring the system Apr 3, 12:29 UTC Investigating - We are currently investigating a problem affecting Codefresh availability
Codefresh’s Status Page - Codefresh availability issue.
2019-04-04
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
what format do you use for your Secrets Manager in #aws to connect to the Codefresh private repo? Can anyone please share an example
2019-04-05
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Status: Image is up to date for cloudposse/build-harness:0.18.0
make: *** No rule to make target 'codefresh/notify/slack/deploy'. Stop.
[SYSTEM] Error: Failed to run freestyle step: Send notification to Slack channel; caused by NonZeroExitCodeError: Container
for step title: Send notification to Slack channel, step type: freestyle, operation: Freestyle step failed with exit code:
2
SendSlackDeployNotification:
title: Send notification to Slack channel
stage: "deploy"
image: cloudposse/build-harness:${{BUILD_HARNESS_VERSION}}
commands:
- make codefresh/notify/slack/deploy
Anyone aware of why this would be happening? LGTM according to build-harness readme and example here: https://github.com/cloudposse/example-app/blob/29f91a718522e4a702d77d172a41ed1f779d42fe/codefresh/pull-request.yaml#L107
Example application for CI/CD demonstrations of Codefresh - cloudposse/example-app
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
This also seems to follow the same pattern https://docs.cloudposse.com/release-engineering/cicd-process/build-charts/#examples
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
likewise make init
fails
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Need more details.
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Not too sure what else to share other than BUILD_HARNESS_VERSION == 0.18.0
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Igor Rodionov
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
So have tried the Codefresh commands of:
...
commands:
- make init
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
and as above
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
do you have declated env vars https://github.com/cloudposse/example-app/blob/29f91a718522e4a702d77d172a41ed1f779d42fe/codefresh/pull-request.yaml#L24
Example application for CI/CD demonstrations of Codefresh - cloudposse/example-app
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
?
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
@oscarsullivan_old ^
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
check this env vars
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Example application for CI/CD demonstrations of Codefresh - cloudposse/example-app
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Collection of Makefiles to facilitate building Golang projects, Dockerfiles, Helm charts, and more - cloudposse/build-harness
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Collection of Makefiles to facilitate building Golang projects, Dockerfiles, Helm charts, and more - cloudposse/build-harness
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
To debug it would be useful to see env vars and codefresh.yaml
data:image/s3,"s3://crabby-images/25add/25add0def8923cb4998312717ccd2821fb7bf49d" alt="casey avatar"
@oscarsullivan_old I just setup a pipeline using the codefresh/notify/slack/deploy/webapp target using BUILD_HARNESS_VERSION=0.18.0
data:image/s3,"s3://crabby-images/25add/25add0def8923cb4998312717ccd2821fb7bf49d" alt="casey avatar"
I would check your environment variables and make sure they are set correctly, I was getting similar errors, and it was because of env variables not being set
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Thanks, I’ll double check both these points (version and undeclared variables)
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
it is most likely the declaration of env vars
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
I did no special setup to use the build-harness tmeplates
data:image/s3,"s3://crabby-images/25add/25add0def8923cb4998312717ccd2821fb7bf49d" alt="casey avatar"
does anyone have suggestions for the strategy I should use for deploying to production from codefresh? I feel unsafe giving the ClusterRole codefresh-role
permission to deploy to the whole cluster
data:image/s3,"s3://crabby-images/25add/25add0def8923cb4998312717ccd2821fb7bf49d" alt="casey avatar"
Or is that the only way possible?
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
I think I use this
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
module "codefresh_user" {
source = "git::<https://github.com/cloudposse/terraform-aws-iam-system-user.git?ref=tags/0.4.1>"
namespace = "${var.namespace}"
stage = "${var.stage}"
name = "codefresh"
}
resource "aws_iam_user_policy_attachment" "default" {
user = "${module.codefresh_user.user_name}"
policy_arn = "arn:aws:iam::aws:policy/AmazonEC2ContainerRegistryPowerUser"
}
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
but not using K8s rn
2019-04-09
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We’ve added support for DocumentDB (MongoDB) to our Codefresh Enterprise terraform module: https://github.com/cloudposse/terraform-aws-codefresh-backing-services
Terraform module to provision AWS backing services necessary to run Codefresh Enterprise - cloudposse/terraform-aws-codefresh-backing-services
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This makes everything that is absolutely essential to running Codefresh Enterprise (onprem) a fully managed service by AWS.
2019-04-10
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Awesome! I made this little example app a little more deployable… Still working out the kinks. https://github.com/codefresh-contrib/example-voting-app
Docker’s Example Voting App. Contribute to codefresh-contrib/example-voting-app development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Requires a few IPs right now and only works with Cloud LB not sure how to make this more portable using Istio or NGINX as both would require a DNS integration using the LB as is while requiring 2 IPs per running Helm Release is a bit much but this is also meant to demo a few things then toss after playing.
2019-04-11
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Bitbucket access issue Apr 11, 11:15 UTC Investigating - We are currently investigating a problem affecting bitbucket integrations
Codefresh’s Status Page - Bitbucket access issue.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Build services disruption Apr 11, 13:11 UTC Investigating - We are currently investigating this issue
Codefresh’s Status Page - Build services disruption.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Bitbucket access issue Apr 11, 14:43 UTC Resolved - The incident has been resolved Apr 11, 11:15 UTC Investigating - We are currently investigating a problem affecting bitbucket integrations
Codefresh’s Status Page - Bitbucket access issue.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Build services disruption Apr 11, 14:43 UTC Resolved - The incident has been resolved Apr 11, 13:11 UTC Investigating - We are currently investigating this issue
Codefresh’s Status Page - Build services disruption.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Infrastructure as code, pipelines as code, and now we even have code as code! =P In this talk, we show you how we build and deploy applications with Terraform using GitOps with Codefresh. Cloud Posse is a power user of Terraform and have written over 140 Terraform modules. We’ll share how we handl
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Here are the slides from the webinar today.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Video will be posted as soon as it’s available.
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Thank you
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Here’s what a PR looks like: https://github.com/cloudposse/testing.cloudposse.co/pull/75
what Demo of adding a new user bucket why GitOps rocks! =)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Here’s the configuration: https://github.com/cloudposse/testing.cloudposse.co/tree/master/codefresh/terraform
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Helm repositories issue Apr 11, 19:04 UTC Resolved - A fix has been deployed to production and confirmed to have fixed the issue. Helm repositories are fully operational. Apr 11, 18:49 UTC Monitoring - The issue has been identified, and the corresponding fix was applied. Helm repositories are accessible again, We’re closely monitoring the platform to ensure everything is working as expected. Apr 11, 18:47 UTC Identified - Currently Helm repositories provided by Codefresh are having issues. This issue is under…
Codefresh’s Status Page - Helm repositories issue.
2019-04-15
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
@Erik Osterman (Cloud Posse) Do you happen to have an example of running https://github.com/cloudposse/github-commenter as a step in Codefresh pipeline using a Docker image? I’ve seen in other project snippets of codefresh.yml formatted examples but nothing in this project.
Command line utility for creating GitHub comments on Commits, Pull Request Reviews or Issues - cloudposse/github-commenter
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Came up with this really quickly.
GitHubCommenter:
title: Add GitHub Comment
image: cloudposse/github-commenter:latest
environment:
- GITHUB_TOKEN=${{GITHUB_TOKEN}} #Must be created see link for info below.
- GITHUB_OWNER=${{CF_REPO_OWNER}}
- GITHUB_REPO=${{CF_REPO_NAME}}
- GITHUB_COMMENT_TYPE=pr
- GITHUB_PR_ISSUE_NUMBER=${{CF_PULL_REQUEST_NUMBER}}
- GITHUB_COMMENT="" #Your custom comment goes here
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this is the latest example that Erik did for the presentation https://github.com/cloudposse/testing.cloudposse.co/blob/osterman-patch-1/codefresh/terraform/pipeline.yml
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the PR looks like this https://github.com/cloudposse/testing.cloudposse.co/pull/75
what Demo of adding a new user bucket why GitOps rocks! =)
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Thanks!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
uses this template file for github-commenter
https://github.com/cloudposse/testing.cloudposse.co/blob/osterman-patch-1/codefresh/terraform/pipeline.yml#L59 (update it for your needs)
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
2019-04-16
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2019-04-18
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Is there a how-to on helmfile in Codefresh like an example codefresh.yml with an explanation on the steps?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Not that well documented
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 “ctl” command can be ignored. It just shows how to call Helmfile
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
In this example, we support both blue/green and rolling
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also, this example shows how we use the monochart
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I’d be happy to jump on a call and walk you through it
2019-04-19
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
How are you guys running stuff like integration tests and system tests? CF can’t directly access internal services that are deployed, so are you guys using some kind of proxy container in the cluster to run these kinds of tests?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
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"
This allows you to run it all in your k8s cluster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’ve used this for things like connecting to artifactory or using consul
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yup this runner allows you to talk to the internal pods of the Kubernetes cluster using the container ips if needed.
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
this will just show up as a different run time environment on your pipeline?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Add the runner to the cluster and then select the runner for the pipeline and everything happens on your cluster.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
related to this, I have a question
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we are about to make our kops cluster private. I know we can use venona, but how do the k8s integrations work then?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yes
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
How to run Codefresh pipelines in your own secure infrastructure
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
Is there a way to split up what runs on CF runtime env and what runs on our infra? I assume that venona still reports everything up to CF UI, right?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yes all comes back to UI
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Each pipeline has a runtime setting. You can use our CLI to call another pipeline from your original as a step in the original and have that child pipeline run on your infra.
data:image/s3,"s3://crabby-images/86d3e/86d3e5f8a456f2d138ca1da1d5c370d19a26f029" alt="mgrube avatar"
I think this should cover our needs, thanks!
2019-04-22
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
Has anyone been using cf_export stating the name of an existing environment variable? I have tried to use it, but the variable output is getting altered. FreeStye Bash Code
- FEATURE=$(echo ${{CF_BRANCH}} | cut -c 9- )
- echo $FEATURE
- cf_export $FEATURE
Output
TI-595
Exporting TI-595=-595
I am seeing the cf_export command parse the static environment variable value vs. storing the defined value with the assignment cf_export $FEATURE
.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Michael Kolb here’s a pipeline step example to setup ENV vars
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
env:
title: Setup Environment
stage: Init
fail_fast: true
image: ${{build_image}}
working_directory: &cwd ${{main_clone}}/${{PROJECT}}
commands:
- cf_export BUILD_HARNESS_VERSION=0.18.0
# Github Commenter
- cf_export GITHUB_OWNER=${{CF_REPO_OWNER}}
- cf_export GITHUB_REPO=${{CF_REPO_NAME}}
- cf_export GITHUB_COMMENT_TYPE=pr
- cf_export GITHUB_PR_ISSUE_NUMBER=${{CF_PULL_REQUEST_NUMBER}}
- cf_export GITHUB_COMMENT_FORMAT_FILE=${{CF_VOLUME_PATH}}/${{CF_REPO_NAME}}/codefresh/terraform/comment.txt.gotmpl
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it exports Codefresh env vars and also those defined in Codefresh UI (Global config section and ENV vars section in each pipeline)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you mean the example does not use the ${{...}}
syntax?
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
So, in the documentation it says that you can state an existing variable
state the name of an existing environment variable (like EXISTING_VAR)
https://codefresh.io/docs/docs/codefresh-yaml/variables/#using-cf_export-command
Codefresh is a Docker-native CI/CD platform. Instantly build , test and deploy Docker images.
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
However, this hasn’t stored that variable assignment
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
and the displayed use case does not show assignment in the code
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
ersion: '1.0'
steps:
freestyle-step-1:
description: Freestyle step..
title: Free styling
image: alpine:latest
commands:
- cf_export VAR1=VALUE1 VAR2=VALUE2 EXISTING_VAR
freestyle-step-2:
description: Freestyle step..
title: Free styling 2
image: ${{VAR1}}
commands:
- echo $VAR2
- curl http://$EXISTING_VAR/index.php
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
is the documentation referencing a pipeline variable defined in the pipeline vs. in the pipeline yaml?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Yes pipeline variables are in the pipeline SPEC file. If you need variables for the pipeline to be set during pipeline execution then you’d use cf_export to have them pop out to pipeline.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
The existing variable section is mentioning step-2 in the YAML above.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
You do not need to specify a variable name before the cf_export
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
thanks, the documentation page could use more examples of cf_export variable assignment like the example that you provided - cf_export GITHUB_OWNER=${{CF_REPO_OWNER}}
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
@Kostis (Codefresh) Can you add this to your backlog to add in some more use cases to this?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
For example command export?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Maybe something like https://github.com/codefresh-contrib/example-voting-app/blob/master/.codefresh/codefresh-dvts.yml#L14
Docker’s Example Voting App. Contribute to codefresh-contrib/example-voting-app development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/1a880/1a880ac694afc16fd5ea2a476caa92861e59f241" alt="Kostis (Codefresh) avatar"
@dustinvb will do
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
they display assignment as static references
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
and the reference EXISTING_VAR
is misleading if this is pulling from the pipeline variable definition vs. an existing variable
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
documentation clarification would help, since I have had to run several builds trying to figure out how the cf_export process handles environment variables
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
is there any documentation on the codefresh/kube-helm
image that provides connection to Kubernetes & Tiller?
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
Are you talking about the image used in our UI steps https://github.com/codefresh-contrib/images/tree/master/kube-helm or Helm step https://github.com/codefresh-contrib/cfstep-helm
useful docker images. Contribute to codefresh-contrib/images development by creating an account on GitHub.
Docker image for Codefresh Helm step. Contribute to codefresh-contrib/cfstep-helm development by creating an account on GitHub.
2019-04-23
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
the docker hub release
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
i found the command that i need kubectl config use-context <<cluster name>>
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
the container had all the tools installed. Unfortunately, there was not documentation on the docker hub site.
2019-04-24
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Hi.. anyone got experience using submodules and codefresh?
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
version: '1.0'
stages:
- build
- push
- prepare
- deploy
steps:
get_git_token:
title: Reading Github token
image: codefresh/cli
commands:
- cf_export GITHUB_TOKEN_EXPORT=$(codefresh get context github --decrypt -o yaml | yq -y .spec.data.auth.password)
updateSubmodules:
image: codefresh/cfstep-gitsubmodules
environment:
- GITHUB_TOKEN=${{GITHUB_TOKEN_EXPORT}}
- CF_SUBMODULE_SYNC=true
- CF_SUBMODULE_UPDATE_RECURSIVE=false
debug:
title: Debug Submodules
image: codefresh/cli
commands:
- codefresh get contexts
- ls -lah /codefresh/volume/my_app/models
- ls -lah /codefresh/volume/my_app/lib/library
BuildingDockerImage:
title: Building Docker Image
stage: "build"
type: build
image_name: ${{IMAGE_NAME}}
working_directory: ./
tag: '${{CF_BRANCH_TAG_NORMALIZED}}'
dockerfile: pm2.Dockerfile
build_arguments:
- APP_ENV=.env-${{CF_PULL_REQUEST_TARGET}}
- PORT=${{PORT}}
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
So it gets my git token, updates the submodules in /codefresh/volume/my_app
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
then does an ls pf those dirs to show me it has cloned (it has)
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
and then in the docker build step I have:
COPY models/* models/
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
but the models/
dir is empty in the container..
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
So I can only assume that /codefresh/volume/my_app is not the path that my_app
is being cloned into during init
and therefore not the context of Docker when building
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
I would recommend trying to set the working_directory: ${{main_clone}}
for the step to ensure you’re in the clone repository directory.
2019-04-25
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Docker incident: Docker Hub elevated errors Apr 25, 17:33 UTC Investigating - Docker has reported an incident affecting Docker Hub Web and Docker Hub Automated Builds components. It shouldn’t affect normal pulling and pushing operations. We will keep monitoring this.
More information here: https://status.docker.com/
Codefresh’s Status Page - Docker incident: Docker Hub elevated errors.
Our system status page is a real-time view of the performance and uptime of Docker products and services.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Codefresh Status - Incident History avatar"
Docker incident: Docker Hub elevated errors Apr 25, 18:10 UTC Resolved - Docker has reported this incident as Resolved. “[Resolved] The issue has been resolved. The DB is backup again.”
More information here: https://status.docker.com/pages/incident/533c6539221ae15e3f000031/5cc1ed78790d0e1ca1c8fcd4 Apr 25, 17:33 UTC Investigating - Docker has reported an incident affecting Docker Hub Web and Docker Hub Automated Builds components. It shouldn’t affect normal pulling and pushing operations. We will keep monitoring this.
More…
Our system status page is a real-time view of the performance and uptime of Docker products and services.
2019-04-30
data:image/s3,"s3://crabby-images/0ea57/0ea57d0df9712c9687d1fa6733ee9e3ef4b4964c" alt="Michael Kolb avatar"
Does Codefresh have API that accepts commands to start an existing pipeline? I have an integration test that will take hours and would like the option to start another pipeline once the integration tests complete.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
https://codefresh-io.github.io/cli/pipelines/run-pipeline/
Usage from a step in pipeline.
Docker’s Example Voting App. Contribute to codefresh-contrib/example-voting-app development by creating an account on GitHub.