#helmfile (2021-05)
Questions and discussion around helmfile https://github.com/roboll/helmfile and https://github.com/cloudposse/helmfiles
Archive: https://archive.sweetops.com/helmfile/
2021-05-03
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
hello all, I have a define :
{{- define "x" -}}
{{ if .value }}
{{- printf .value -}}
{{ else }}
{{- exec "kubectl" (list "get" "configmap" "data" "-n" "namespace" "--output=jsonpath={.data.userdata }} }" ) -}}
{{ end }}
{{ end }}
and a template to call it
userdata: {{ template "x" . }}
is there a way to pass params to the define line from template like
(dict "value" .Values.data.user "key" "region")
If I could pass params like namespace, resource type, endpoint in jsonpath… then I could use only few defines and not lots of… thanks in advance
data:image/s3,"s3://crabby-images/a1c0f/a1c0f392cee61a2da37d311b1979734e43a44971" alt="Antoine Taillefer avatar"
I believe so, try:
{{ template "x" (merge (dict "value" .Values.data.user "key" "region") .) }}
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
I think I found it. my problem was I use kubectl to get data if env not exists and I just passed the value to the jsonpath and it did not work, so I hjad to pass the full –output… part and it works.
data:image/s3,"s3://crabby-images/25e04/25e04bfcd8de21ae44ff0fb9e2de20d0d9c85cb7" alt="Joaquin Menchaca avatar"
How do you configure helm --name_template
in a helmfile.yaml
? I didn’t see an option for this, and I was digging through the code, I couldn’t spot if it was or was not supported.
2021-05-04
data:image/s3,"s3://crabby-images/abb31/abb3190c6f305d282cf76fa42a07ede0b274bfa0" alt="yuri avatar"
Hey guys, could not find an answer to what i was looking for…
is there a way to pass ENV VARS to helm-secrets
plugin?
the plugin supports some flags that im interested in like:
HELM_SECRETS_DRIVER_ARGS
and HELM_SECRETS_DEC_SUFFIX
, i tried to export them before helmfile runs and also with prepare hooks, but it doesn’t seems to affect the plugin in any way, if i export them and then use directly helm secrets ….
it works
data:image/s3,"s3://crabby-images/abb31/abb3190c6f305d282cf76fa42a07ede0b274bfa0" alt="yuri avatar"
ah, nvm, i see helmfile support this already https://github.com/roboll/helmfile/blob/ae942c5288895c84c79171e5446773e4cb41c4ce/pkg/helmexec/exec.go#L277
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
2021-05-05
data:image/s3,"s3://crabby-images/0e007/0e007e867db122c95fd92bf1fdad44e1cb9e18f3" alt="CH avatar"
Is it at all possible to set values for a release from a file located inside a chart? Something like:
releases:
- name: my-app
chart: my-helm-repo/my-app
version: 1.0.2
values:
- {{ .Release.ChartPath }}/values/{{ .Environment.Name }}.yaml
data:image/s3,"s3://crabby-images/0e007/0e007e867db122c95fd92bf1fdad44e1cb9e18f3" alt="CH avatar"
The goal here is to version our environment values same way our app charts are versioned, and promote them in lockstep.
data:image/s3,"s3://crabby-images/0e007/0e007e867db122c95fd92bf1fdad44e1cb9e18f3" alt="CH avatar"
So that the same commit that adds a new value to a chart can also populate it in the environment values files (and likewise for removal or other changes).
data:image/s3,"s3://crabby-images/0e007/0e007e867db122c95fd92bf1fdad44e1cb9e18f3" alt="CH avatar"
Would be super simple if we could just include the environment values files in the chart itself, instead of trying to download them from Git or something
data:image/s3,"s3://crabby-images/72274/7227482e022bbf2e4339da3767f115c9e8a6f02c" alt="Vladimir Avdoshka avatar"
interesting idea, I wonder to hear if there is some solution
2021-05-07
2021-05-11
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
hello all, let’s say I have dev and prod env-s If I would like to deploy dev I just need to run helmfile apply, for prod I need to mention with -e prod apply… is there a way to check it from a variable that I can get from cluster ?
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
Hi all, are remote helmfiles via HTTPS supposed to work? E.g. this helmfile.yaml leads to an error:
helmfiles:
- path: <https://raw.githubusercontent.com/cloudposse/helmfiles/master/releases/external-dns/helmfile.yaml>
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yes, we use it everywhere. Best to show the error message.
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
This is the error message:
no matches for path: <https://raw.githubusercontent.com/cloudposse/helmfiles/master/releases/external-dns/helmfile.yaml>
There are no repositories defined in your helmfile.yaml.
This means helmfile cannot update your dependencies or create a lock file.
See <https://github.com/roboll/helmfile/issues/878> for more information.
err: no releases found that matches specified selector() and environment(default), in any helmfile
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
Also reported it as a GH issue https://github.com/roboll/helmfile/issues/1842
Hi, using this minimal helmfile.yaml… helmfiles: - path: https://raw.githubusercontent.com/cloudposse/helmfiles/master/releases/external-dns/helmfile.yaml … when running helmfile deps I get thi…
data:image/s3,"s3://crabby-images/9bc5f/9bc5f8a9da582d4057fd0034186e12abcc32bc7b" alt="Michael Seiwald avatar"
Just to add I don’t mean “Git over HTTPS” but direct “plain” HTTPS.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
aha, good distinction. I see we’re using this:
helmfiles:
- path: "git::<https://github.com/cloudposse/helmfiles.git@releases/efs-provisioner.yaml?ref=0.112.0>"
Which is “Git over HTTPS”, and I don’t know if we’ve tested the “plain” HTTPS.
2021-05-12
data:image/s3,"s3://crabby-images/81973/81973d49134804a89039d8fcc7e9f0ffd1ed2739" alt="Arthur Jaron avatar"
Hi guys, I’ve just inherited a rather large codebase using helmfile, which is new to me. In there is the following construct: helmfile.yaml
releases:
- name: namespace-dev
chart: ../../../../charts/namespace
version: 0.0.1
createNamespace: false
values:
- values.yaml
- test: {{ .Values.testing }}
- namespace: dev
values.yaml
testing: yes
I’m simply trying to read “testing” from the yaml file, but I get this error message:
in ./helmfile.yaml: in .helmfiles[0]: in namespaces/helmfile.yaml: error during helmfile.yaml.part.0 parsing: template: stringTemplate:11:24: executing "stringTemplate" at <.Values.testing>: map has no entry for key "testing
What am I doing wrong? This should be trivial from what I’ve read so far…
data:image/s3,"s3://crabby-images/75a76/75a7670cc9c7e016d0995c2242dfb5dbb32150b7" alt="Rene Hernandez avatar"
The testing
field won’t be available in that scope if it is defined in a values file. You would need to move it to another yaml file that you would import as an environment (default one or specific one)
data:image/s3,"s3://crabby-images/75a76/75a7670cc9c7e016d0995c2242dfb5dbb32150b7" alt="Rene Hernandez avatar"
e.g:
environment.yaml
testing: yes
helmfile.yaml
environments:
default:
values:
- ./environment.yaml
releases:
- name: namespace-dev
chart: ../../../../charts/namespace
version: 0.0.1
createNamespace: false
values:
- values.yaml
- test: {{ .Values.testing }}
- namespace: dev
data:image/s3,"s3://crabby-images/da5f5/da5f53c8b536540779d28edd4ef2a9c5e126aaec" alt="brokencode avatar"
Hi, I’m wondering, can helmfile is meant to be used like helm-operator/controller? I.e. can you deploy it to kubernetes and have it sync changes from github/gitlab and apply them to the cluster? If so, are there any example deployments available?
data:image/s3,"s3://crabby-images/a1a25/a1a2552c07b7a64517c7f76cbafad031c3fa4268" alt="Ievgenii Shepeliuk avatar"
I’ve read somewhere some time ago that ArgoCD has some support or can be hacked to process Helmfiles from git repos :)
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
helmfile apply
inside CI/CD pipelines does this for about 1y in one of dev envs
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
You also could find this thread useful: https://github.com/roboll/helmfile/issues/153
Flux, Argo and helmfile-operator are mentioned there
So that we can leverage everything helm provides to power helmfile :) User-defined Lua functions included in charts (Perhaps in Helm v3) Helm chart repositories to distribute versioned helmfiles fo…
2021-05-13
2021-05-16
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Guys? Is possible to set kubeconfig context in Helmfile TF helmfile_release_set
resource ? Seem its possible in helmfile_release
, but not in *_set.
@mumoshu is this intentional ? thanks
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Probably it’s not intentional
2021-05-17
data:image/s3,"s3://crabby-images/6558c/6558c44f2367d2b8ea099b2521fc2281295f6c94" alt="anilkumar861 avatar"
Can helmfile hooks can be placed in seperate file and include that file under releases section? I need to manage hooks seperately for each release. Can it be possible?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Maybe no.
But would you mind giving me an ideal and imaginary configuration example that you have in your mind?
I was thinking that you can just use {{ readFile }}
to include some file under releases
data:image/s3,"s3://crabby-images/b8ae4/b8ae40e0a1268ed2c27583a382781fd8234d3953" alt="Tencho Tenev avatar"
Hello, I’ve been trying out helmfile today and want to propose it to my team. However, I stumbled upon an issue with the diff plugin that helmfile uses for helmfile diff
. I’d like to find a workaround or contribute a fix for this before I demo the tool to my team. The revision is added as a label in many of our charts, I don’t know if this is common or bad, but it causes helmfile apply
to sync every time. Does anyone have suggestions?
Hi, we have a pod label as follows that includes the helm revision number as a value: tags.datadoghq.com/version: {{ .Release.Revision | default 0 | quote }} This seems to work fine with helm, but … |
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Tencho Tenev Hey! Thanks for bringing it up. This sounds like a good chance to contribute.
Hi, we have a pod label as follows that includes the helm revision number as a value: tags.datadoghq.com/version: {{ .Release.Revision | default 0 | quote }} This seems to work fine with helm, but … |
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
https://github.com/databus23/helm-diff/issues/253#issuecomment-842733991
I think the first step would be to try to build your own helm-diff after changing this line, so that helm-diff use helm upgrade --dry-run
instead of template
https://github.com/databus23/helm-diff/blob/master/cmd/helm3.go#L141
Hi, we have a pod label as follows that includes the helm revision number as a value: tags.datadoghq.com/version: {{ .Release.Revision | default 0 | quote }} This seems to work fine with helm, but … |
A helm plugin that shows a diff explaining what a helm upgrade would change - databus23/helm-diff
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/b8ae4/b8ae40e0a1268ed2c27583a382781fd8234d3953" alt="Tencho Tenev avatar"
Hi, so I did the first step and have helm diff using upgrade dry-run instead of template. This produces diffs showing the next revision which makes more sense.
However, the perfect behaviour for me is to produce no diff if the only reason for change is the revision changing. This is not so trivial, in fact, I think it requires a change in helm itself.
After looking at a few projects, I feel like using release revision in all charts is not a best practice. I will suggest changes to the charts my team owns to remove the use of revisions. I may still raise a PR on helm diff with the change for upgrade instead of template because at least the result is more intuitive.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Tencho Tenev ah, gotcha! just fixing the chart makes sense in that case. good.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
In case you can’t fix the chart for whatever reason, I think it’s still a good idea to raise a feature request to helm-diff
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
to add something like ignoreDifferences
in ArgoCD
https://argoproj.github.io/argo-cd/user-guide/diffing/
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
It seems to be implemneted by removing the keys at the jsonpaths before computing diff https://github.com/argoproj/argo-cd/blob/b37eee1054e42c873699460dd5e2447c2f9fe5a6/util/argo/normalizers/diff_normalizer.go#L28-L63
Declarative continuous deployment for Kubernetes. Contribute to argoproj/argo-cd development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
helm-diff
does textual diffing here
https://github.com/databus23/helm-diff/blob/d42b177462211ce1f15db07f6309359818a005f9/diff/diff.go#L157
so adding some logic for ignoreDiefferences
here would work
A helm plugin that shows a diff explaining what a helm upgrade would change - databus23/helm-diff
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
again, if fixing the chart works, that’s okay
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
just my two cents
2021-05-18
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Guys? Is possible to render helmfile including namespaces ? helmfile template
does not honor namespaces specified in helmfile.yaml
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
probably not https://github.com/roboll/helmfile/issues/805
data:image/s3,"s3://crabby-images/935f2/935f2319313973bc76d276be722740711d92b14e" alt="Lea Zusman avatar"
Hi :slightly_smiling_face:
I’m trying to add multiple hooks that perform few kubectl commands.
For example, helmfile.yaml
:
.....
releases:
.....
- name: XXX
chart: ./charts/...
version: 0.0.1
labels:
testable: true
values:
- ./templates/XXX.values.yaml.gotmpl
hooks:
- events: ["prepare"]
showlogs: true
command: "kubectl"
args: ["annotate", "configMap", "XXX", "-n", "YYY", "meta.helm.sh/release-name=XXX"]
- events: ["prepare"]
showlogs: true
command: "kubectl"
args: ["annotate", "configMap", "XXX", "-n", "YYY", "meta.helm.sh/release-namespace=YYY"]
- events: ["prepare"]
showlogs: true
command: "kubectl"
args: ["label", "configMap", "XXX", "-n", "YYY", "app.kubernetes.io/managed-by=Helm"]
Now, it looks like there is no way to combine those hooks together (it throws an exception) is there a way to add few hooks \ few commands in one hook - or is there other way to implement this logic ? (using a bash command and run them all together ? )
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
haven’t tried that myself. what kind of “exception”s d o you actually see?
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
We are successfully using subsequent postsync hooks:
hooks:
- events: ["postsync"]
showlogs: true
command: "sleep"
args: ["30s"]
- events: ["postsync"]
command: "kubectl"
args: ["annotate", "--overwrite", "ns", ...]
- events: ["postsync"]
command: "kubectl"
args: ["label", "--overwrite", "ns", ...]
data:image/s3,"s3://crabby-images/99f14/99f142c769556c4d75482d90487388acdad54bf3" alt="cool-doge"
data:image/s3,"s3://crabby-images/935f2/935f2319313973bc76d276be722740711d92b14e" alt="Lea Zusman avatar"
I got an exception about invalid index. apparently I added unnecessary spaces
data:image/s3,"s3://crabby-images/935f2/935f2319313973bc76d276be722740711d92b14e" alt="Lea Zusman avatar"
2021-05-19
data:image/s3,"s3://crabby-images/c9f5e/c9f5e946df105d0042fa96d51534fc7a9ec3c4ed" alt="Jake avatar"
Just a bit curious as to what precedence applies when specifying muliple values against a release e.g.
releases:
- name: a
values:
- a.yaml
- b.yaml
Do values in a.yaml
override b.yaml
(or vice versa)?
data:image/s3,"s3://crabby-images/c9f5e/c9f5e946df105d0042fa96d51534fc7a9ec3c4ed" alt="Jake avatar"
I’m cheekily using mergeOverwrite
at the minute, just for a current “workaround”
data:image/s3,"s3://crabby-images/75a76/75a7670cc9c7e016d0995c2242dfb5dbb32150b7" alt="Rene Hernandez avatar"
b.yaml
should override a.yaml
data:image/s3,"s3://crabby-images/c9f5e/c9f5e946df105d0042fa96d51534fc7a9ec3c4ed" alt="Jake avatar"
ah cool, cheers.
2021-05-20
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Hi all, I’ve been trying to use https://docs.gitlab.com/ee/user/clusters/applications.html#install-gitlab-runner-using-gitlab-cicd
to install gitlab runners on my cluster thats integrated with Gitlab. It mentions that the registration token can be passed in via environment variable which I’ve set in my CICD variables.
However, when I try to run this, my values.yml is not picked up nor is my registration token. Upon investigating, I found their helmfile for it here https://gitlab.com/gitlab-org/cluster-integration/cluster-applications/-/blob/master/src/default-data/gitlab-runner/helmfile.yaml
I notice its doing
{{- if env "GITLAB_RUNNER_GITLAB_URL" }}
- gitlabUrl: "{{ env "GITLAB_RUNNER_GITLAB_URL" }}"
{{- end }}
{{- if env "GITLAB_RUNNER_REGISTRATION_TOKEN" }}
- runnerRegistrationToken: "{{ env "GITLAB_RUNNER_REGISTRATION_TOKEN" }}"
{{- end }}
{{- if env "GITLAB_RUNNER_VALUES_FILE" }}
- {{ env "GITLAB_RUNNER_VALUES_FILE" | quote }}
{{- else }}
- {{ env "CI_PROJECT_DIR" }}/.gitlab/managed-apps/gitlab-runner/values.yaml
{{- end }}
but that doesnt seem to be working at all. Any ideas how I could get this to work?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hey!
it should just work, as you can indeed use go template expressions like {{ env }}
in your helmfile.yaml template.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
how did you confirm it doesn’t work?
have you tried running helmfile build
to see what the rendered helfile.yaml template looks like?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
have you tried running it with --debug
like helmfile --debug template
to see what helmfile sees?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
well the helmfile is in a container that I dont have access to
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
and in this case, I have added the GITLAB_RUNNER_REGISTRATION_TOKEN
as a CICD variable in gitlab which means its available to the environment. but the token doesnt get picked up and the pods fail to register — this is how I know it doesnt work
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah okay… then the only thing i could suggest would be
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
try running something like echo $GITLAB_RUNNER_REGISTRATION_TOKEN | shasunm
on CI and compare the output with that of the same command run on your local machine
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
to see if the envvar is really set or not
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
helmfile should just read the env and that’s all i can say from helmfile’s perspective
2021-05-21
data:image/s3,"s3://crabby-images/9b0c9/9b0c9a926422e17db13db22d6af1f935ce005907" alt="Victoria H avatar"
Hey all. I’m brand new to helmfile, testing it out as a way to migrate away from my team’s current strategy of using a bash script to clobber together a base helm chart repository with 1+ other repositories with specific environment configurations. The repositories for the different environments contain both definitions files (simple enough to translate to helmfile), as well as specific configuration files that are either added to the base repo or overwrite existing files in the base repo (for example, in apache-httpd2, there is a deployment-specific.conf in the base repo as well as in the repo(s) for the other environments, so that gets overwritten). Does helmfile offer the functionality to insert these environment-specific configuration files depending on the deployment?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
environments and release templates?
environments: https://github.com/roboll/helmfile#environment release templates: https://github.com/roboll/helmfile/blob/master/docs/writing-helmfile.md#release-template--conventional-directory-structure
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9b0c9/9b0c9a926422e17db13db22d6af1f935ce005907" alt="Victoria H avatar"
I think that might be on the right track. A better way of stating it– can helmfile be used to manage inserting cluster-specific FILES in addition to chart values? A good example of this in our repository is the use of .crt and .pem files for specific sub-charts. These live in directories adjacent to the microservice’s chart, and there is a template for a config map that takes everything in these directories as data for the config map ({{ (.Files.Glob "securityconfig/*").AsConfig | indent 2 }}
). Say I wanted to deploy to my dev cluster, could I use the helmfile to include the desired .crt and .pem files for that environment?
2021-05-22
2021-05-24
2021-05-25
data:image/s3,"s3://crabby-images/abbc1/abbc1fbb34fb8c3aa1474c58277290952b82bce2" alt="Denis Palnitsky avatar"
Hi, I’m using helm file in a CD pipeline to deploy Helm charts from a Gitops repository. It works great and I think you guys did a great job I have to questions:
- Is there a way to deploy all environments with one command? I want to be able to add env in helmfile in my gitops, commit it and see helmfile deploys it automatically.
- how do you people solve environment cleanup problem when you run helmfile in a pipeline? For example, I removed a chart or an env from a helmfile in gitops repo and I would like to detect those cleaned up resources automatically and remove them
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Don’t know about the first point, we never needed this. As for the second we have a organisational solution. If one wants to remove a release or something else from the helmfile it should be done in stages: first, installed
should be set to false
for corresponding releases, and second, only after this configuration is applied a block can be removed from a helmfile. We don’t do gitops, nonetheless I believe the same principle can be applied.
data:image/s3,"s3://crabby-images/abbc1/abbc1fbb34fb8c3aa1474c58277290952b82bce2" alt="Denis Palnitsky avatar"
Yep, seems like it’s the only solution for now
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Regarding the first point, there’s no built-in functionality that helps it. you need to script it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
For the second, right that installed: false
is the only solution. That way you are extra sure helmfile would ever remove releases that are explicitly marked so.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
We’ve once discussed about storing some helmfile “state” in the k8s cluster so that we can track what are already installed onto the cluster but now missing in the definitions. But it turned out to be defeat one of helmfile goals of being a “thin” wrapper around helm.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
(It’s arguable if helmfile is really “thin” today but it would still be a great idea to keep it as simple as possible
2021-05-26
2021-05-30
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
Hello @mumoshu. I would like to share my current prototype of a “central remote helmfiles” repository approach. When I was pointing that it would be nice to have remote git sync updates in a GH issue I mentioned that I had an idea on “central repository” like cloudposse…
While without any documentation on cloudposse/helmfiles I haven’t seen any goals of using that code, nonetheless I tried to implement an approach that seems suit my needs: https://github.com/dysnix/helmfiles.
Thinking of the upcoming improvements to helmfile, I feel that sharing the above might be a good source for ideas for the next versions Such as remote values and valueTemplates))
Dysnix Distribution of Helmfiles for Kubernetes. Contribute to dysnix/helmfiles development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hey! thanks for sharing
Dysnix Distribution of Helmfiles for Kubernetes. Contribute to dysnix/helmfiles development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
replied to your issue based on that https://github.com/roboll/helmfile/issues/1817#issuecomment-851724588
Hello @mumoshu! It would be nice to be able to update remote git sub-helmfiles. I've suddenly found this thing for myself and already envision some useful scenarios. It would be nice to have an…