#helmfile (2020-08)
Questions and discussion around helmfile https://github.com/roboll/helmfile and https://github.com/cloudposse/helmfiles
Archive: https://archive.sweetops.com/helmfile/
2020-08-01
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
@mumoshu Not sure if this is a usual/tipical scenario but i started using helmfile in my CI/CD pipeline and one requirement I have is after the deployment is succesful (this can be confirmed with the wait parameter) I need to execute a manual command inside the deployed pod. For this I use the helmfile list with labels in order to identify the helm release name and then get the pod from the release name. Not sure if there’s a better way to do this? I parse the output of helme list with json (which is why I also got an issue opened here https://github.com/roboll/helmfile/issues/1270)
When doing a helmfile list –output=json the labels presented in the output are of csv format. I do a lot of jq parsing to get meaningful information from the releases for other external scripts an…
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
You could use a job with post-install helm hook
When doing a helmfile list –output=json the labels presented in the output are of csv format. I do a lot of jq parsing to get meaningful information from the releases for other external scripts an…
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
That post-install trigger only if the deployment is succesfull?
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
How would I target the job strictly at the container from the deployment?
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
I will run in another container inside your pod
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
it’s always a bad pattern to run a command inside a running container
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
Agreed but in this case i need to execute a binary inside the container
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
you can run a job with exact same image I guess https://helm.sh/docs/topics/charts_hooks/
Describes how to work with chart hooks.
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
if it runs in same pod, it will have same environment
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
you use this in pre-install
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
I remember going this route and having a problem but i will take a look once again and see what comes up
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
for our staging, it deploys database, kafka schema, etc, and after, helm deploys ours pods
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
Ah I remember one thing is to see the log output in the ci/cd pipeline and also have it fail if there’s an error
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
about what?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I think postinstall
should be what you want. It’s called only after successful install.
In the hook command, perhaps using
kubectl get po -l release={{` {{.Release.Name}} `}}
and then kubectl exec
on the pod would work?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
postsync
is called after install/upgrade regardless of success/failure, and you should be able to check {{.Error}}
for emptiness to determine if it was successful or not. try that instead of postinstall you need testing after upgrade, too.
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
@mumoshu postinstall are run locally? I thought hook was only for resource creations like jobs
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hooks can be any local processes. you’ll usually use preopare
and cleanup
hooks for creating/deleting charts and presync
for creating resources not managed by required by release
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
for postsync
… im not sure. i thought i heard anyone used it for notification
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and postinstall
is a specialization of postsync
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
data:image/s3,"s3://crabby-images/456a6/456a6e8b90fe290ce123a0896af3616629a022e0" alt="Paul Catinean avatar"
Maybe I’m going about it the wrong way or something
2020-08-02
2020-08-03
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Does anyone use helm3 in CI/CD ( maybe inside helmfile too)? How do you deal with missing real --force
in helm3 compared to helm2? It looks like https://github.com/helm/helm/pull/7431 isn’t going to be merged to add real force to helm3.
An additional optional flag –recreate can be passed on upgrade (or rollback) of a release. In combination with the –force flag the following strategies are employed when updating a resource (whic…
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
you can put these specific resources in hooks, see https://github.com/kubernetes/kubernetes/issues/45398#issuecomment-478619253 for an example
PodDisruptionBudget is immutable at this moment. It would be a nice improvement to allow changes to it, at the least to the minAvailable field. Not sure whether this counts as a bug or a feature re…
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Are you talking about delete&recreate on every helm upgrade
, including cases when immutable resource isn’t changed ?
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
yes. well of course it may or may not apply to your use-cases, depending on which resources you need to “force update”. In our case for example, we used to do it on PDB, and now we’re doing it on Jobs, so deleting and recreating is not an issue
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
but I agree that it’s a pain
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I hit this with Service and StatefulSet
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
which part of the spec ?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I use the following to install / upgrade a chart: ./helm upgrade –install –set rbac.create=false –set controller.replicaCount=2 –set controller.service.loadBalancerIP=$ip –wait main-ingress st…
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
do helm hooks require to add on-the-fly helmfile json patches to stock charts to apply hooks to these charts?
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
ah yes, the volumeClaimTemplates
in the statefulset, we had this issue too…
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
hopefully the pvc size won’t change often, you can do a 1-time operation (backup, delete, recreate, restore data)
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
PVC isn’t affected during statefulset recreation
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
so backup+restore isn’t required
data:image/s3,"s3://crabby-images/056ca/056ca4097546f5c0cbd2f7b4c2ae2de6b2b14262" alt="Vincent Behar avatar"
about json patches, that depends on the charts, if they support adding annotations or not
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
and it’s still a semi-solution just to emulate helm2 behaviour with drawbacks like recreating the resource every time
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I have helmfile apply
over 50 releases in a dev CI/CD pipeline, and it works fine, but it’s helm2, not 3.
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
We are dealing with this manually. I.e. we do helm delete
and then trigger pipelines with helmfile and stuff. Not an ideal solution for sure.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
yes, donwtime and side effects are everywhere
data:image/s3,"s3://crabby-images/bcfb3/bcfb392db73d6c1fa91b4427c7e74940a7e46886" alt="hari avatar"
Hi Everyone,
data:image/s3,"s3://crabby-images/bcfb3/bcfb392db73d6c1fa91b4427c7e74940a7e46886" alt="hari avatar"
i have come across a interesting requirement in my helm charts
data:image/s3,"s3://crabby-images/bcfb3/bcfb392db73d6c1fa91b4427c7e74940a7e46886" alt="hari avatar"
kind: Deployment
spec:
template:
metadata:
annotations:
checksum/config: {{ include (print $.Template.BasePath "/configmap.yaml") . | sha256sum }}
in this config , i need to change the configmap.yaml name dynamically w.r.t environment Like this one checksum/config: {{ include (print $.Template.BasePath “/configmap-{{ .Release.Name }}.yaml”) . | sha256sum }}
data:image/s3,"s3://crabby-images/bcfb3/bcfb392db73d6c1fa91b4427c7e74940a7e46886" alt="hari avatar"
OR checksum/config: {{ include (print $.Template.BasePath “/configmap-{{ .Values.env }}.yaml”) . | sha256sum }}
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Do you wanna mix helm gotmpl with helmfile gotmpl in the same line ?
data:image/s3,"s3://crabby-images/bcfb3/bcfb392db73d6c1fa91b4427c7e74940a7e46886" alt="hari avatar"
Does anyone have come across this situation ?
data:image/s3,"s3://crabby-images/bcfb3/bcfb392db73d6c1fa91b4427c7e74940a7e46886" alt="hari avatar"
unfortunately, none of these will work
2020-08-04
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Hi, I have a remote chart including somes yaml value files (i.e values-dev.yaml) I thought I would have been able to do that:
releases:
- name: xxx
chart: helm-private-repo/foo
values:
- values-dev.yaml
But I have the following response:
in ./helmfile.yaml: failed processing release xxx: values file matching "values-dev.yaml" does not exist in "."
It is working when the chart is local but not working when the chart is remote. Is there a way to tell helmfile to use values-dev.yaml from the downloaded chart instead of trying to find values-dev.yaml in ‘.’ ?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
So, you wanna pull values from remote instead of local ?
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
well, values are already in the chart. I was hoping that I could just reference the file I want to use
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
I know I can put an URL to retrieve values but its a real shame since everything is already included in the chart
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
helmfile doesn’t have access to the chart, it just calls helm
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Ok, and helm is not able to use values from a remote chart then? the file must be present when we run helm -f xxx ?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
you need to get values into helmfile, thus shell script(helm3 show values?) or remote yaml file in helmfile is your option.
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
ok Thanks for confirming. Shame this is not possible straight away
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I don’t think that keeping unused values file in the chart is a common practice.
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Ok. So It maybe make sense to move values-XXX.yml along with helmfile instead of keeping it in the chart
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
this looks a common practice. Keep charts and settings separated. You hit some sensitive data in settings usually and you cannot store it in the chart anyway.
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Ok Thanks for the advice. I saw couple of charts storing values-XXX.yaml in their repo, but not that many. I will keep them separated.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
storing values-XXX.yaml in their repo
I suppose it was a git repo, not a helm repo with charts archives.
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Its a git repo, but its in the chart archive. Example: https://github.com/bitnami/charts/tree/master/bitnami/rabbitmq
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
NOTE: The default values file included inside of a chart must be named values.yaml.
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
yes for this case this is clear. I just would have liked a comment on the helm website that we can’t specify custom value file even if its included in the chart
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Create a PR
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Yes
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
otherwise, would the following work ? I haven’t tried it yet: https://github.com/zendesk/helm-secrets/issues/61#issuecomment-429053736 Its pulling the chart locally through hooks
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
yep, this should be fine except it will trigger on every helmfile
2020-08-05
data:image/s3,"s3://crabby-images/c30bb/c30bb5a512018f67960ef254c3f49af568093f63" alt="Jonathan avatar"
I’m trying to get some secrets from gcp secret manager into a string, but I’m having some issues. What I have is a reference to a secret in my common/dev.yaml
file like so:
key1:
user: "<ref+gcpsecrets://projectname/secret-name?version=latest#/path/to/user>"
password: "<ref+gcpsecrets://projectname/secret-name?version=latest#/path/to/password>"
The issue is that when I try to use the value of the secrets in a values.gotmpl file like so: string: "{{ .Values.key1.user }}:{{ .Value.key1.password}}"
I get the actual string "<ref+gcpsecrets://projectname/secret-name?version=latest#/path/to/secret>"
from each value, rather than the value of what the secret reference is. Is there any way to force the reference to be evaluated before being passed along? Or should i structure this some other way? The reason I have it like this is because I need to have the values combined into a string so that the code that is using these values is happy.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
did you tried something similar to
string: "{{`{{ .Values.key1.user }}:{{ .Value.key1.password}}`}}"
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Jonathan could u try “fetchSecretValue”?
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/c30bb/c30bb5a512018f67960ef254c3f49af568093f63" alt="Jonathan avatar"
2020-08-06
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Is it possible to deploy a raw kubernetes manifest in helmfile/helm without using kubectl? For example, If i want to deploy a kubernetes ingress only.
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
I think recently this became supported? something with go-getter
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
…as chart (#1374) This, in combination with #1172, allows you to use go-getter
-supported URL for K8s manifests on chart
, so that Helmfile automatically fetches it and then turning it into a te…
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
This, in combination with #1172, allows you to use go-getter-supported URL for K8s manifests on chart, so that Helmfile automatically fetches it and then turn it into a temporary local chart, which…
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Do you mean I should be able to deploy like that ?
releases:
- name: ingress
chart: ./raw/ingress-dev.yaml
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
I have the following error returned:
COMBINED OUTPUT:
Error: only unpacked charts can be updated
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
there is an example in the pull request
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
I’ve never used it personally
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
he targets `
git::<http://github.com/jetstack/cert-manager.git@deploy/crds?ref=v0.15.2>
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
which is here https://github.com/jetstack/cert-manager/tree/master/deploy/crds (except this is master and not that tag)
Automatically provision and manage TLS certificates in Kubernetes - jetstack/cert-manager
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
but the tl;dr is that its a repo directory with only a bunch of yaml manifests
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Which I believe is what your goal is ?
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
Oh yes its working if I just pass the folder ./raw instead of ./raw/ingress-dev.yaml
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
So, I guess in your case if you wanted a single manifest you’d need to do a directory with just that single manifest inside it
data:image/s3,"s3://crabby-images/c9ada/c9adafe27fbbbf7504324eca6baa9fccc774ee73" alt="Florent Valdelievre avatar"
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
In practice do you guys just apply via sync
or apply
with helmfile in your ci/cd ?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
helmfile apply with helm2 in dev env
data:image/s3,"s3://crabby-images/52f5e/52f5ef30e89d02426b188df6fafde7e3cd5a85c7" alt="Shawn Petersen avatar"
No
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Guys? I am getting:
error during gitlab-test2.yaml.part.0 parsing: template: stringTemplate:22:24: executing "stringTemplate" at <.Values.foo.common.kind>: map has no entry for key "foo"
Not sure whats wrong…
environments:
default:
values:
foo:
common:
kind: Secret
repositories:
- name: incubator
url: <https://kubernetes-charts-incubator.storage.googleapis.com>
releases:
- name: test
namespace: test
createNamespace: true
chart: incubator/raw
version: 0.2.3
values:
- resources:
- apiVersion: v1
kind: {{ .Values.foo.common.kind }}
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Is it related to https://github.com/roboll/helmfile/issues/932 ?
TL;DR; I want to add a new helmfile.yaml field to make templating helmfile configs easier. Problem Helmfile's double-rendering has opened a wide variety of use-cases that requires you to write …
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Works! Thanks I already tried:
environments:
default:
values:
- foo:
common:
kind: Secret
repositories:
- name: incubator
url: <https://kubernetes-charts-incubator.storage.googleapis.com>
releases:
- name: test
namespace: test
createNamespace: true
chart: incubator/raw
version: 0.2.3
values:
- resources:
- apiVersion: v1
kind: "{{ .Values.foo.common.kind }}"
which is not working…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
sry this is very confusing indeed, but the root cause here is that environments.NAME.values
needs to be a yaml array, rather than hash
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
to allow merging multiple values entries
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so it should be
environments:
default:
values:
- foo:
common:
kind: Secret
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the best practice is to separate environments
and other parts of your helmfile.yaml with ---
like
environments:
default:
values:
foo:
common:
kind: Secret
---
repositories:
- name: incubator
url: <https://kubernetes-charts-incubator.storage.googleapis.com>
releases:
- name: test
namespace: test
createNamespace: true
chart: incubator/raw
version: 0.2.3
values:
- resources:
- apiVersion: v1
kind: {{ .Values.foo.common.kind }}
so you get a much better error
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
in ./helmfile2.yaml: failed to read helmfile2.yaml: reading document at index 1: yaml: unmarshal errors:
line 4: cannot unmarshal !!map into []interface {}
which tells that you’re mistakenly trying to define values
as map, rather than array([])
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Guys? I am trying to add gitlab helm chart repository:
repositories:
- name: custom
url: git+<https://gitlab.com/gitlab-org/charts/gitlab?ref=v4.2.1&sparse=0>
releases:
- name: gitlab
namespace: gitlab
createNamespace: true
chart: custom/gitlab
, but getting:
COMBINED OUTPUT:
Error in plugin 'helm-git': Target file name has to be either 'index.yaml' or a tgz release
Error: looks like "git+<https://gitlab.com/gitlab-org/charts/gitlab?ref=v4.2.1&sparse=0>" is not a valid chart repository or cannot be reached: plugin "helm-git" exited with error
Any idea? Of course that I am aware of official charts ( another thing is that gitlab helm chart is somehow complicated, its using nested subcharts )
Thanks
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
You can’t use a git repository as source for helm
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
your repository
must be for helm chart, with a specific index.html for listing available charts, etc
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
gitlab provides a repo : <https://charts.gitlab.io/>
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
Cloud Native GitLab Helm Chart
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
@Issif of course i can https://github.com/aslafy-z/helm-git, point is not to use charts from https://charts.gitlab.io/
Helm plugin to fetch charts from Git repositories. Contribute to aslafy-z/helm-git development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
Hi, is it really not possible to just specify a plain HTTPS URL for a sub-helmfile like this?
helmfiles:
- path: <https://our-nexus/bla/bla/bla>
- path: git::<ssh://git@>.....
The first URL gives a no matches for path
error message. The second (git::ssh
) works..
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
I found out that the URL has to be <https://our-nexus/><dir>@<file>
but then helmfile tries to fetch just the directory which leads to a HTTP 404..
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
<http://example.com/dir@file>
isn’t a http url
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
True, but it’s what helmfile expects. Otherwise you get an error like this (after digging into the code and fmt.Printing some errors that are otherwise not exposed to the user)
invalid src format: it must be `[<getter>::]<scheme>://<host>/<path/to/dir>@<path/to/file>?key1=val1&key2=val2: got <https://my.ordinary.http.url/dir/file>
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
So something like <http://example.com/dir/file>
is not even considered by helmfile
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
It kind of makes sense because helmfile needs the whole directory since the remote helmfile can also reference remote files.
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
But you cannot “download” a directory over http which makes me think that HTTP ist just not supported at all for remote statefiles?
2020-08-07
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@here So we’ve been a helmfile user for many years now. I think there were only a couple dozen stars on the repo when we started, now there are thousands. The project has transformed dramatically during this time and we’ve all benefited immensely from this. I just want to say how grateful I am for everyones help on this, but especially your’s @mumoshu because it would not have been possible without it. I sincerely don’t understand how you can be so productive on all these projects (helmfile, helm-diff, eksctl, brigade, helm, kube-aws, etc) and squash bugs as fast and tirelessly as you do, but you still manage to pull it off. If there ever was such a thing as a 10x engineer, you’re the definition of it. Anyways, we appreciate all the tremendous effort you put forth not just on coding but also on supporting feature requests, answering questions, and just always being so helpful. I regret not stepping up sooner, but just want to share our support and hope others will too! https://github.com/sponsors/mumoshu
Support mumoshu’s open source work
data:image/s3,"s3://crabby-images/91017/910177adba94615aa40428c968883b16f580e2bd" alt="1000"
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Just a few hours ago I had a conversation with my colleagues and I mentioned @mumoshu in a way that it’s hard to imagine how he does so many things with such a quality and passion. An example for all of us.
Support mumoshu’s open source work
data:image/s3,"s3://crabby-images/91017/910177adba94615aa40428c968883b16f580e2bd" alt="1000"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
helmfile + variant2 =
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I can’t tell you how much I appreciate all your help!
Honestly, I had mixed feelings working on OSS. It’s too tough in regard to how much time and effort I need to put onto it, while I’ve been grateful for having chances of any kinds of collaborations with you all.
Discussing about potential bug, get to distill it into the root cause, finally fixing it together. Receiving feature requests, talking about use-cases, come up with a solution together. Prototyping something and receiving early feedback about it(recent examples would be terraform-provider-helmfile and variant2). I think I love all of those experiences and processes while working on OSS - probably that’s why I’ve been maintaining OSS like Helmfile until now.
Sponsorship - I think this is my first time to receive sponsorships more than one or two at once. Simply I had never realized I would receive such many supports! Combining all my experiences so far, your kind words, and this time, sponsorships, I’m feeling encouraged and motivated more than ever for my work now .
Thank you all for continuing to work with me. Expect me to keep this
// Excuse me for slow response. I had to have some time to organize what I felt
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
more than 30 likes, but just 8 sponsors on github
2020-08-08
data:image/s3,"s3://crabby-images/c38c0/c38c0d13679c3a759d24ef73f126f9a864c73fad" alt="Vadim Bauer avatar"
Hello could someone explain how condition
is working, somehow I don’t get it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrm.. I’m not familiar with the condition
in helmfile
- we haven’t used it, but my guess is that it works like the installed
flag?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
My guess is that borrows from the upstream convention in the Chart.yaml
. See https://helm.sh/docs/topics/charts/#the-chartyaml-file
Explains the chart format, and provides basic guidance for building charts with Helm.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Anyone know the difference between condition
and installed
?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
condition
with false
doesn’t delete the release, it’s just ignored, like there is no such release.
installed/installedTemplate
with false
will delete --purge
release.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Taken from state.go
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
op | true | false |
--------------------------------------
installed | install | delete --purge |
condition | install | skip/ignore |
kind of
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hrm… then how is condition different from enabled
? sounds like condition
is the same as enabled
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
do we have a keyword enabled
in helmfile?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hah, you know - I must be confused. Doesn’t look like it and then it all makes more sense.
2020-08-10
2020-08-11
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Has anyone run into issues before when deploying releases in the same helmfile using needs:
but the latter releases are using a custom resource created by a CRD from the earlier releases?
STDERR:
Error: Failed to render chart: exit status 1: Error: unable to build kubernetes objects from release manifest: unable to recognize "": no matches for kind "Vault" in version "vault.banzaicloud.com/v1alpha1"
Error: plugin "diff" exited with error
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Yes. A recently introduced disableValidation flag might help. I’ve just mention this in a different thread:)
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
the Vault
custom resource is created in the release previous and they are forming a dependency with needs:
2020-08-12
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Does anyone else know if its a bug or feature that you can’t do an apply
to a helmfile which contains two releases which have a CRD/CR relationship because of the helm-diff
?
The diff will run on both releases before the apply
and the second release will fail becaues the CR it tries to diff doesn’t exist as a type yet, since its created in the first chart by a CRD
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
data:image/s3,"s3://crabby-images/0ad2d/0ad2d2f49faf486393b7a85c28a2874ee04d952e" alt="TJMiller avatar"
can i use vals for helm repo credentials?
2020-08-13
data:image/s3,"s3://crabby-images/7531e/7531ea6897ce7b10e1a5d99759e0d39fd3784185" alt="s_slack avatar"
Eks+helm: I have many applications using helm charts but these charts also have a secrets.yaml. This contains an application.properties
encrypted. I want to remove the username/password from the property file and store it in AWS SSM. This way I would be able to decrypt the property file, have its values in helmfile. After that create a ConfigMap template that gets populated based on the property values from helmfile.
I don’t want to commit the username/password so I would store it in AWS SSM. Though not sure if this is a good idea or how to pass the username/password to the deployment object and not have it in plain text. GoDaddy has this https://ca.godaddy.com/engineering/2019/04/16/kubernetes-external-secrets/ and I wonder if there are any other alternatives. Cheers
Ps. I use helm + helmfile + helm-git
Engineering teams at GoDaddy use Kubernetes with secret management systems, like AWS Secrets Manager.
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Helmfile has native support for getting values from SSM as it uses vals (https://github.com/variantdev/vals)
Helm-like configuration values loader with support for various sources - variantdev/vals
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
The remote-secrets.md file has some very basic examples, and the vals readme has a section on using SSM to get more info on how to use it
data:image/s3,"s3://crabby-images/7531e/7531ea6897ce7b10e1a5d99759e0d39fd3784185" alt="s_slack avatar"
Nice. That simplifies a bunch. Though how do I handle the fact that I need username/password either in application.properties or as env variable. Though I don’t want it in plain text in the pod or in git.
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Create a k8s secret using helmfile, and load that secret as environment variables in the pod.
data:image/s3,"s3://crabby-images/7531e/7531ea6897ce7b10e1a5d99759e0d39fd3784185" alt="s_slack avatar"
That sounds much easier than I thought. I will try it out. Thank you @bradym
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
np
data:image/s3,"s3://crabby-images/7531e/7531ea6897ce7b10e1a5d99759e0d39fd3784185" alt="s_slack avatar"
Curious. Is it common practice to put password in secrets file not encrypted (just encoded base64)? Even though it retrieves from SSM one could easily get the password from secrets
data:image/s3,"s3://crabby-images/7531e/7531ea6897ce7b10e1a5d99759e0d39fd3784185" alt="s_slack avatar"
I have a SSM parameter with the following values:
param1: value1
param2: value2
I use in values.yaml.gotmpl
...
Secrets:
{{ .Environment.Values.someapp | expandSecretRefs | toYaml | nindent 2 }}
in someapp.yaml
...
- releases:
- name: some-app
values:
- ../releases/someapp/values.yaml.gotmpl
- Secrets:
- <ref+awsssm://someapp/testssm?region=us-west-2>
in secrets.yaml
...
data:
{{- range $key, $value := .Values.Secrets}}
{{ $value | b64enc | quote | indent 2 }}
{{- end }}
returns:
...
+ data:
+ 0: "param1: value1\nparam2: value2"
I can’t seem to be able to get the $key= param1 and $value= value1, etc for those variables. The SSM entry gets populated in $value only, $key is always empty.
data:image/s3,"s3://crabby-images/ea00f/ea00f9343a17d095895c39968df1348b3cfe92c4" alt="bbhupati avatar"
Alternatively, you can try this option https://thefirstapril.com/2019/06/29/Secret-Management-in-Helm-Kubernetes/ Use helm secrets plugin to encrypt/decrypt the secret file with AWS KMS and pass the encrypted file to helmfile so that all the secret files which are stored in version control system are encrypted #helm secrets enc secrets.yaml releases:
- name: test
namespace: default
version: “0.2.0”
chart: test
set:
- name: “clusterName” value: test secrets:
- secret.yaml
Secret management in HelmHelm is a Kubernetes package manager, Helm helps developer deploy their application to Kubernetes. Helm also provide chart as dependencies for your application at https://hub.
2020-08-14
2020-08-15
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
just saw that even gitlab is using helmfile => https://gitlab.com/gitlab-com/gl-infra/k8s-workloads/gitlab-com
Kubernetes Workload configurations for GitLab.com This repository is mirrored on https://ops.gitlab.net/gitlab-com/gl-infra/k8s-workloads/gitlab-com
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
helmfiles for helm releases in gitlab.com infrastructure
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
They propose some apps in their managed k8s clusters and for installing them they use helm right. A apps I develop will be added in a next release and that’s why I added it on helm hub last week
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
I am just positively surprised by their adoption. What app did you work on ?
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
A simple daemon to help you with falco’s outputs. Contribute to falcosecurity/falcosidekick development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
falco has been integrated by gitlab in 13.2
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
oh that is nice! But what I mean is they are using helmfile to setup their own infrastructure (what runs gitlab.com) as well now..
data:image/s3,"s3://crabby-images/6ed29/6ed2936fc5e2cb980f4b7bc052d9c7bf1978299e" alt="Issif avatar"
Oh I get your point now, great
data:image/s3,"s3://crabby-images/cbc4d/cbc4d568d15ac0fe563887f3d43ea5258b284e20" alt="vgdubrea avatar"
@Pierre Humberdroz Good find , But I am just wondering why are you positively surprised? I mean is this something that you expect they could have rolled their own solution with helm ? we primarily use gitlab.com for everything we do with our customers and are heavy consumers of pretty much all the solutions they offer.
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
No but a lot of people I talk to are not even aware that helmfile exists. And seeing some bigger company adopting it makes me happy! I also wanted to share how others set their helmfiles up.
2020-08-16
2020-08-19
2020-08-20
data:image/s3,"s3://crabby-images/ba930/ba9300c794ebaee5b0c1e2bad61ec37ba68d94de" alt="Sam Buckingham avatar"
Does anyone know if you can use remote helm chart values? For instance:
releases:
- name: ingress-internal-{{ requiredEnv "PLATFORM_ENV" }} # name of this release
namespace: ingress
chart: ingress
values:
- git::<ssh://[email protected]:ORG/REPO.git//values/ingress/@internal_{{> requiredEnv "PLATFORM_ENV" }}.yaml?ref=master
wait: true
condition: ingress-internal.enabled
atomic: true
installed: true
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
helmfile allows to get values from exec, thus you may adapt it with git as a source too
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
There are some workarounds like: https://github.com/roboll/helmfile/issues/469#issuecomment-613782055
Also this is merged: https://github.com/roboll/helmfile/pull/1296
Hey, I think it would be awesome to have the option of pulling values files over http/s and git ssh. Something like: values: - https://some-url.com/master/values.yaml.gotmpl - <git://[email protected]>:…
This PR enables the user to specify a remote path for an environment values file, e.g., environments: cluster-azure-us-west: values: - git://git.company.org/helmfiles/global/azur>…
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I was thinking https://github.com/roboll/helmfile/pull/1296 is related to values inside environment solely and doesn’t affect release/template values
This PR enables the user to specify a remote path for an environment values file, e.g., environments: cluster-azure-us-west: values: - git://git.company.org/helmfiles/global/azur>…
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Ah, @voron probably you are right. Thanks for a tip
data:image/s3,"s3://crabby-images/cbc4d/cbc4d568d15ac0fe563887f3d43ea5258b284e20" alt="vgdubrea avatar"
@Sam Buckingham may I know how are you using condition in the helmfile
2020-08-24
data:image/s3,"s3://crabby-images/ae6e4/ae6e4c909e172514b399eadf9c5f32cde6bfa5ae" alt="4c74356b41 avatar"
hey folks, I’m having a really weird issue, where I’m using the same container for local testing and for CI (container has helmfile, terraform, helm, etc) and after I deploy from my local, CI build redeploys everything with a really weird diff:
+ apiVersion: networking.istio.io/v1alpha3
+ kind: VirtualService
+ metadata:
+ name: raven
+ namespace: ccc-testing
labels:
app.kubernetes.io/name: raven
app.kubernetes.io/instance: testing
app.kubernetes.io/component: raven
app.kubernetes.io/part-of: ccc
- app.kubernetes.io/managed-by: Helm
- spec:
- hosts:
- - xxx
- gateways:
- - yyy
- http:
- - headers:
- response:
- set:
- Strict-Transport-Security: "max-age=31536000; includeSubDomains; preload"
- route:
- - destination:
- host: raven
- port:
- number: 8080
- timeout: 10000s
+ app.kubernetes.io/managed-by: Helm
+ spec:
+ hosts:
+ - xxx
+ gateways:
+ - yyy
+ http:
+ - headers:
+ response:
+ set:
+ Strict-Transport-Security: "max-age=31536000; includeSubDomains; preload"
+ route:
+ - destination:
+ host: raven
+ port:
+ number: 8080
+ timeout: 10000s
data:image/s3,"s3://crabby-images/ae6e4/ae6e4c909e172514b399eadf9c5f32cde6bfa5ae" alt="4c74356b41 avatar"
so essentially its exactly the same contents of the file. any ideas what to look at? and this happens with every rendered file
2020-08-25
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Hey @mumoshu, just ran across this funny little message
err 0: glob patterns in release values and secrets is not supported yet. please submit a feature request if necessary
err 1: glob patterns in release values and secrets is not supported yet. please submit a feature request if necessary
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
apparently you tried to write something similar to
values:
- whatever/*.yaml
which is not yet supported
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Haha yup. Was nice to get such a thorough error message
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
glad to hear it worked! btw, pls feel free to open a feature request if you really need it
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Just wrote a small bash script to print out all the files in the dir in a yaml format and use an exec
2020-08-26
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
When using release templates what’s the difference between
values:
- config/{{`{{ .Release.Name }}`}}/values.yaml
and
valuesTemplate:
- config/{{`{{ .Release.Name }}`}}/values.yaml
? There is not much info about this.
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
It’s interesting that for secrets there is no template or it’s a typo
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Both do the same. *Template
were added to use inside yaml templates to have an ability to merge template and release values. When you use values
in template and values
in release - release values override template values. Same with valuesTemplate
- using it in both template and release leads to release valuesTemplate
overrides template’s one. But when you use valuesTemplate
in template and values
in release(or vise versa) - resulting helm values are merged from values
and valuesTemplate
values. Similar with set/setTemplate
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Huge thanks! Is it documented somewhere and I missed it? Or you know it from inspecting the code/following issues?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
maybe here
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
We use yaml templates, that’s why I’m aware of this.
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
I’ve seen this, but without trying is hard to get the idea. You description is way better. Thanks again!
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
np
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Guys? How can I override variables if I am using:
# test-helmfile.yaml
environments:
default:
values:
- foo: bar
helmfiles:
- ../../helmfiles.d/global-helmfile.yaml
# global-helmfile.yaml
environments:
default:
values:
- foo: {{ env "FOO" }}
repositories:
releases:
helmfile -f test-helmfile.yaml apply
Problem is that foo
is empty and is overriden by nested helmfile ..
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
I want to be able to deploy global-helmfile.yaml with environemnt variable support and also test-helmfile.yaml with static vars and possible release override. Any idea?
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Solved with:
helmfiles:
- path: ../../helmfiles.d/global-helmfile.yaml
values:
- foo: bar
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
What does not work me is:
# test-helmfile.yaml
helmfiles:
- path: ../../helmfiles.d/global-helmfile.yaml
values:
- foo: bar
# global-helmfile.yaml
environments:
default:
values:
- foo: {{ requiredEnv "FOO" }}
repositories:
releases:
error calling requiredEnv: required env var `FOO` is not set
foo
var should be overriden with static foo
value, isnt it a bug? @mumoshu
( Its working with {{ env "FOO" }}
, but it can render empty value, if FOO is not specified, which is problematic )
Thanks
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
foo: bar
is merged AFTER global-helmfile.yaml is executed as a go template. so, it must be {{ env "FOO" }}
if you need to override foo
in the callee side from the caller
data:image/s3,"s3://crabby-images/5eb0f/5eb0f5ed82aee17abd01263f1a25b6a31cf86516" alt="Alex avatar"
hello all,
does anyone know if there is a way to specify environments per release? example:
environments:
development:
staging:
production:
templates:
app: &app
namespace: {{ .Environment.Name }}
chart: charts/{{`{{ .Release.Name }}`}}
missingFileHandler: Error
values:
- apps/{{`{{ .Release.Name }}`}}/values.{{ .Environment.Name }}.yaml
- apps/{{`{{ .Release.Name }}`}}/version.{{ .Environment.Name }}.yaml
releases:
- name: MyApp
<<: *app
- name: MySecondApp
<<: *app
here, is it possible to specify that MySecondApp is only for development?
(I see ways around it like having 3 separate helmfile.<environment>.yaml or having multiple templates but not ideal)
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
one possible option is to use installed/installedTemplate
in your template or release
installedTemplate: {{ eq .Environment.Name "development" | toYaml }}
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
another possible option is to use similar condition
environments:
development:
values:
- MySecondApp:
enabled: true
staging:
values:
- MySecondApp:
enabled: false
production:
values:
- MySecondApp:
enabled: false
templates:
...
releases:
- name: MyApp
<<: *app
- name: MySecondApp
condition: MySecondApp.enabled
<<: *app
Of course, you may use files to load environment values instead of inlining
data:image/s3,"s3://crabby-images/5eb0f/5eb0f5ed82aee17abd01263f1a25b6a31cf86516" alt="Alex avatar"
thank you, that helps
2020-08-27
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Does anyone else still have problems with releases going to different kubeContext are still getting duplicate release errors?
STDERR:
Error: release: already exists
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
where do you specify kubeContext
?
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
at the release level
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
what helmfile version do you use ?
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
v0.125.5
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
could you pls reproduce this error on the latest version, and then retry with --debug
to get actual helm arguments?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I suppose release: already exists
error is from helm, thus your helm may use wrong context. It’s better to test on single release using selector by release name
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
we use context at helmDefaults
and template level, don’t noticed any unfixed issues.
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
does this release actually exist ?
helm --kube-context dev_eu-frankfurt-1_dataplane --namespace example ls -la
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I suppose this issue is related to helm solely. Are you able to reproduce this issue by executing helm with all these args from debug log ?
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
well, i can see its issuing the helm release to the same kubecontext twice
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
that shouldn’t be happening
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
We are using a nested loop to generate our releases
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
but it shouldn’t produce this outcome. Here is an example
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
releases:
{{- range (list "us-ashburn-1" "us-phoenix-1") }}
{{- $region := . }}
{{- range (list "controlplane" "dataplane") }}
{{- $okeKubeContext := (printf "%s_%s_%s" "dev" $region .) }}
- name: example-grafana
chart: bitnami/grafana
kubeContext: "{{ $okeKubeContext }}"
{{- end }}
{{- end }}
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
ah, dynamic releases. I’m able to reproduce this issue - all the releases get the same kubeContext - the last generated one. It may be by design - you’re on the same single helmfile environment, kubeContext isn’t used as some uniq part to distinguish releases, and releases with the same name+namespace are merged in therms of kubeContex.
File a bug or submit a PR.
Interesting results are with
- name: example-grafana
chart: "{{ $okeKubeContext }}"
kubeContext: "{{ $okeKubeContext }}"
chart is uniq, while k8s context is the same in debug output. This leads to expected release: already exists
But as soon as “release name + namespace” are uniq - no issues - k8s context is uniq too.
- name: "{{ $okeKubeContext }}"
chart: bitnami/grafana
kubeContext: "{{ $okeKubeContext }}"
or
- name: example-grafana
chart: bitnami/grafana
namespace: "{{ $okeKubeContext }}"
kubeContext: "{{ $okeKubeContext }}"
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
I thought kubecontext WAS used as a unique part to distinguish a release? https://github.com/roboll/helmfile/pull/1390
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
or at least it was intended to be
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
and yes, all of your tests above mimic exactly what I’m seeing
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
@mumoshu just CC’ing you here because I brought this up to you before as well
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Currently helmfile does not take kubeContext at the release level into the uniqueness of a release. For a use-case where you want to deploy the same chart to many clusters you have to use dynamic r…
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
and now you don’t hit duplicate release
error in helmfile, but you get actual duplicate releases.
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
thank you for all your help
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
you’re welcome
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
2020-08-28
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
Hello! I’m trying to reuse values block for different helmfiles but getting template error: template: stringTemplate26: executing “stringTemplate” at <.Values.location>: map has no entry for key “location” It works if i use the same values in “values block” instead of global environments. Any ideas on how to fix this? Or suggestions how to get what i want other way? Thanks! (I’d like to keep all in one file if possible)
---
environments:
default:
values:
~_ - a: b
+ ---
helmfiles:
~ - path: git::<https://git.com/ops/[email protected]?ref=master>
+ - path: git::<https://git.com/ops/[email protected]?ref=master>
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
could you pls provide larger example? I don’t see variable location
in your example.
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
Sure, In addition to the first snippet, suppose
git::<https://git.com/ops/[email protected]?ref=master>
Looks like this:
---
repositories:
~ - name: {{ .Values.a }}
~ url: <https://chartmuseum>.{{ .Values.a }}
~ username: {{ .Values.a }}
~ password: {{ .Values.a }}
helmDefaults:
createNamespace: false
wait: true
timeout: 600
templates:
default: &default
~_ chart: {{ .Values.a }}/{{`{{ .Release.Name }}`}}
missingFileHandler: Warn
releases:
~ - name: cluster-metadata
<<: *default
namespace: kube-system
~ version: {{ .Environment.Values | get "overrides.cluster-metadata" "0.1.0" }}
labels:
default: true
~ app: cluster-metadata
values:
- cluster:
~ location: {{ .Values.a }}
~ zone_prefix: {{ .Values.a }}
~ zone_postfix: {{ .Values.a }}
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
then error will be during helmfile.yaml.part.0 parsing: template: stringTemplate18: executing “stringTemplate” at <.Values.a>: map has no entry for key “a”
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
so it cannot template
url: <https://chartmuseum>.{{ .Values.a }}
Which i assume it should get from
environments:
default:
values:
~_ - a: b
In the first file
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
helmfiles:
allows to specify values per each add helmfile. Did you tried to move your values to file and then specify this file under values? See Advanced Configuration: Nested States
on https://github.com/roboll/helmfile
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
That’s my next option. I was hoping to describe all my app layer in one file per cluster :<
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
It’s not possible then? I should stick with separate files for values?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Just move values to files from the beginning
environments:
default:
values:
- /path/to/values.yaml
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I’m not sure if this helps unfortunatelly
data:image/s3,"s3://crabby-images/f5ed5/f5ed506d97a480ab50e3cc80e96e16d80bf5bc53" alt="owlz avatar"
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
You’ll need either a values: block under each sub-helmfile definition or environments: inside each sub-helmfile manifest:)
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from helmfile avatar"
v0.125.9: Merge pull request #1442 from roboll/fix-duplicate-with-kubectx-per-r… c575587 (HEAD, tag: v0.125.9, origin/master, origin/HEAD, master) Merge pull request <a class=”issue-link js-issue-link” data-error-text=”Failed to load title” data-id=”688441462” data-permission-text=”Title is private”…
c575587 (HEAD, tag: v0.125.9, origin/master, origin/HEAD, master) Merge pull request #1442 from roboll/fix-duplicate-with-kubectx-per-release f2dfa7c Fix kubeContext not taken into account for rele…
…elease Fix kubeContext not taken into account for release uniqueness
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from helmfile avatar"
v0.126.0: Fix build error after helmfile build --embed-values
addition
cd0ecc5 (HEAD, tag: v0.126.0, origin/master, origin/HEAD, master) Fix build error after helmfile build –embed-values addition
<a class=”commit-link” data-hovercard-type=”commit”…
cd0ecc5 (HEAD, tag: v0.126.0, origin/master, origin/HEAD, master) Fix build error after helmfile build –embed-values addition dc6c59d Print command output in line (#1354) 0fc0869 feat: helmfile bu…
This is a follow-up for #1436
2020-08-29
2020-08-31
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
Hey All, good morning :slightly_smiling_face: Is it intended that helmfile repos
attempts to template all releases? I was attempting to use it as a pre-step to my releases and it was taking a long time to run. Looking at --debug
, it appears to be templating all the releases.
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
ah, looks like the trick for my setup is not to supply an env
data:image/s3,"s3://crabby-images/ad460/ad460ca870f23ab6a17e40ca9469f0d19f587205" alt="jason800 avatar"
so no environments are imported/run into the main helmfile, have to use --allow-no-matching-release
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from helmfile avatar"
v0.126.1: Fix test flake for commonLabels
(#1449)
3e6542e (HEAD, tag: v0.126.1, origin/master, origin/HEAD, master) Fix test flake for commonLabels (<a class=”issue-link js-issue-link” data-error-text=”Failed to load title” data-id=”689738084” data-permission-text=”Title is private”…
3e6542e (HEAD, tag: v0.126.1, origin/master, origin/HEAD, master) Fix test flake for commonLabels (#1449) d3daea3 Fix panic on hook since v0.126.0 (#1448) 19d7942 Add experimental “forceNamespace” …