#helmfile (2021-04)
Questions and discussion around helmfile https://github.com/roboll/helmfile and https://github.com/cloudposse/helmfiles
Archive: https://archive.sweetops.com/helmfile/
2021-04-06
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
any idea why it does not work like values ?
skipping missing values file matching "../config/{{ .Release.Name }}/patches.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/{{ .Environment.Name }}-patches.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/merge.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/merge.yaml.gotmpl"
skipping missing values file matching "../config/{{ .Release.Name }}/{{ .Environment.Name }}-merge.yaml"
skipping missing values file matching "../config/app/values.yaml"
Successfully generated the value file at ../config/app/values.yaml.gotmpl. produced:
My templates settings are :
templates:
default: &default
missingFileHandler: Debug
values:
- ../config/{{ .Release.Name }}/values.yaml
- ../config/{{ .Release.Name }}/values.yaml.gotmpl
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}.yaml
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}.yaml.gotmpl
secrets:
- ../config/{{ .Release.Name }}/secrets.yaml
- ../config/{{ .Release.Name }}/secrets.yaml.gotmpl
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}-secrets.yaml
strategicMergePatches:
- ../config/{{ .Release.Name }}/merge.yaml
- ../config/{{ .Release.Name }}/merge.yaml.gotmpl
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}-merge.yaml
jsonPatches:
- ../config/{{ .Release.Name }}/patches.yaml
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}-patches.yaml
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
Did you find an example that it should work like this ?
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
no, just tried based on values. it works. so on the same file I have the Release.Name… few lines after i don’t have it ?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
I don’t see that strategicMergePatches
and jsonPatches
do support files with/without rendered name.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
it may be better to use valuesTemplate in templates, btw, but it’s not related to the issue you’re seeing
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
so I cannot give dynamic address of the patch file? I need to set it under all apps in release ?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
try and see. If hardcoded file name works - you may submit a PR to get generated names to function there, or open an issue.
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
jsonPatches:
- ../config/app/patches.yaml
then it finds the patch and patches the resources I would like.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
and what’s with strategicMergePatches
?
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
same
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
if I hardcode the app name it finds… if not it does not replace the {{}} with the value and searches under ../config/{{ .Release.Name }}/patches.yaml
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
where I don’t have the file
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
well, sometimes hack with quoting like
{{`{{ .Release.Labels.app }}`}}
may work
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
skipping missing values file matching "../config/{{ .Release.Name }}/patches.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/{{ .Environment.Name }}-patches.yaml"
skipping missing values file matching "../config/{{{{ .Release.Name }}}}/merge.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/merge.yaml.gotmpl"
same
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
it looks it templating only values and secrets. is that correct?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
as I said above, you may submit a PR to get generated names to function there, or open an issue. it may be some trivial fix, or may not, IDK
data:image/s3,"s3://crabby-images/78b32/78b32c23de91d2229fb5452dd2fa9d4f2b7e2a11" alt="Andrey Bronin avatar"
@voron I can confirm, we’re using the same approach
dockerized: &dockerized
namespace: {{ .Environment.Values.namespace }}
missingFileHandler: Warn
labels:
group: docker
values:
- envs/dockerized.yaml.gotmpl
- envs/{{`{{ .Environment.Name }}`}}/dockerized.yaml.gotmpl
- envs/common/dockerized/{{`{{ .Release.Name }}`}}.yaml.gotmpl
- envs/{{`{{ .Environment.Name }}`}}/{{`{{ .Release.Name }}`}}.yaml.gotmpl
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
there is no issue w/ values/valuesTemplate
or secrets
. It’s specific to strategicMergePatches
and jsonPatches
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
yes. I have issue with patches not with values and secrets.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
@Balazs Varga did you tried hack with
{{`{{ ... }}`}}
?
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
yes I tried.. did not work
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
file a PR or an issue on GH, that’s all I can advise.
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
will do. Now I am trying to find where is it templating the secrets and values. I mean the path only because I need the path to be templated. the patch contains hardcoded data.
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
well, another possible option is to fork chart and fix it to get rid of patches
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
yeah but this looks more elegant way than modifying charts.
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
today I will spend to solve this if cannot then will modify charts
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Hey! I guess you would like valuesTemplate
@Balazs Varga cc @voron
For more info find valuesTemplate
in
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.
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
yes, but if I would like to use here it does not work.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I thought there’s no reason it doesn’t work under templates
.
You might be just merging-in the template afterwards using <<: *default
, right?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
How did your helmfile.yaml with templates
and releases
looked like when you found valuesTemplate not working?
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
templates I mentioned. releases was simple like this:
releases:
- name: init
namespace: default
chart: ../chart/init
<<: *default
so the idea was if I put the values and secrets and patches to the selected folder it will template and use it… it searches under those folders but as you see it does not template the patches lines:
skipping missing values file matching "../config/{{ .Release.Name }}/patches.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/{{ .Environment.Name }}-patches.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/merge.yaml"
skipping missing values file matching "../config/{{ .Release.Name }}/merge.yaml.gotmpl"
skipping missing values file matching "../config/{{ .Release.Name }}/{{ .Environment.Name }}-merge.yaml"
skipping missing values file matching "../config/app/values.yaml"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Balazs Varga Could you try (literally) valuesTemplate
instead of values
for values, then?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
You can’t access release template from within values
, which is supposed to be a yaml array of plain strings
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
On the other hand each item in valuesTemplate
is considered a go template with accses to release template
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
yeah will try… few sec
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Also if you’d need to do the same templating on file paths in secrets
, unfortunately it isn’t supported today. But it should be a relatively easy addition to Helmfile. Please feel free to open a dedicated feature request for that. It should look like secretsTemplate
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
thanks. using valuesTemplate it works
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
that is fine to me if I cannot put merge into secret “folder”.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Oh really? Okay then! I just thought you’d want the same level of reusability for the secrets
array, too
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
no, I just wanted to have jsonpatches and mergepatches under config folder to have a light helmfile.d file
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
templates:
default: &default
missingFileHandler: Debug
valuesTemplate:
- ../config/{{ .Release.Name }}/values.yaml
- ../config/{{ .Release.Name }}/values.yaml.gotmpl
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}.yaml
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}.yaml.gotmpl
- ../config/{{ .Release.Name }}/merge.yaml
- ../config/{{ .Release.Name }}/merge.yaml.gotmpl
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}-merge.yaml
- ../config/{{ .Release.Name }}/patches.yaml
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}-patches.yaml
secrets:
- ../config/{{ .Release.Name }}/secrets.yaml
- ../config/{{ .Release.Name }}/secrets.yaml.gotmpl
- ../config/{{ .Release.Name }}/{{ .Environment.Name }}-secrets.yaml
this worked to me… if somebody else will have the same issue.
Successfully generated the value file at ../config/test/merge.yaml.gotmpl. produced:
apiVersion: apps/v1
kind: Deployment
metadata:
name: test
namespace: test
spec:
...
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Ah, so what I wanted to say was that I’m afraid that this part isn’t working as you might have expected:
secrets:
- ../config/{{ .Release.Name }}/secrets.yaml
Almost certainly this is translated to as-is, without templating, not ../config/test/secrets.yaml
as you might have expected, but ../config/{{ .Release.Name }}/secrets.yaml
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
that still works
skipping missing values file matching "../config/prometheus/default.yaml"
skipping missing values file matching "../config/prometheus/default.yaml.gotmpl"
skipping missing values file matching "../config/prometheus/merge.yaml"
skipping missing values file matching "../config/prometheus/merge.yaml.gotmpl"
skipping missing values file matching "../config/prometheus/default-merge.yaml"
skipping missing values file matching "../config/prometheus/patches.yaml"
skipping missing values file matching "../config/prometheus/default-patches.yaml"
skipping missing secrets file matching "../config/prometheus/secrets.yaml"
skipping missing secrets file matching "../config/prometheus/secrets.yaml.gotmpl"
skipping missing secrets file matching "../config/prometheus/default-secrets.yaml"
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
I just don’t use it here.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
oh really!!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
We use templated names with secrets for some time ago, similar to
secrets:
- ../../live/{{ .Environment.Name }}/{{`{{ base .Release.Chart }}`}}/secrets-{{`{{ .Release.Name }}`}}.yaml
data:image/s3,"s3://crabby-images/99f14/99f142c769556c4d75482d90487388acdad54bf3" alt="cool-doge"
2021-04-07
data:image/s3,"s3://crabby-images/20fd8/20fd81ce027fe4455bb93a68313ac5e093fd02d3" alt="abhishrant.m avatar"
Hi everyone, this is probably me missing something simple but for some reason I am not able to use the new “waitForJobs” config.
I added it to the release section as follows
releases:
- name: test
...
wait: true
waitForJobs: true
timeout: 60
helmfiles:
...
{{ if eq .Environment.Name "cluster" }}
- path: environments/cluster/test.yaml
{{ end }}
environments:
cluster:
The helmfile apply
command fails with
...
[1] in /home/helmfile/helm-installer/resources/helmfile.yaml: in .helmfiles[1]: in environments/cluster/test.yaml: failed to read test.yaml: reading document at index 1: yaml: unmarshal errors:
[1] line 7: field waitForJobs not found in type state.ReleaseSpec
Helm and helmfile version
bash-5.0# helm version
version.BuildInfo{Version:"v3.5.0", GitCommit:"32c22239423b3b4ba6706d450bd044baffdcf9e6", GitTreeState:"clean", GoVersion:"go1.15.6"}
bash-5.0# helmfile version
helmfile version v0.138.7
data:image/s3,"s3://crabby-images/a1c0f/a1c0f392cee61a2da37d311b1979734e43a44971" alt="Antoine Taillefer avatar"
Hi, this is a recent addition, see https://github.com/roboll/helmfile/pull/1715 and related commit merged in master: https://github.com/roboll/helmfile/commit/2618cfb38b20d867a977f2b295059893d23e507a but not yet released.
data:image/s3,"s3://crabby-images/20fd8/20fd81ce027fe4455bb93a68313ac5e093fd02d3" alt="abhishrant.m avatar"
Oh, I did not notice this. I thought 138.7 had it cause the readme mentioned the new config. Thanks for the clarification!
data:image/s3,"s3://crabby-images/a1c0f/a1c0f392cee61a2da37d311b1979734e43a44971" alt="Antoine Taillefer avatar"
Yep, the README is the one of the master branch
data:image/s3,"s3://crabby-images/20fd8/20fd81ce027fe4455bb93a68313ac5e093fd02d3" alt="abhishrant.m avatar"
Is there any ETA for the next version?
data:image/s3,"s3://crabby-images/6bf4a/6bf4a8426a38683495fa16e79951c72dd07e57d3" alt="voron avatar"
2021-04-08
2021-04-11
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Does anyone rely on helmfile’s current behavior that helmfile -l name=foo apply
NOT failing when foo
had some needs
to other releases?
https://github.com/roboll/helmfile/pull/1772 can be a breaking change to you so please chime-in and leave your comments if you have opinions
Currently, this is going to be a breaking change for whoever relied on the helmfile's existing behavior of helmfile -l foo=bar apply silently ignoring the unfulfilled needs. Since this change, …
2021-04-13
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Good evening everyone. I’m trying to learn helmfile
and am struggling to figure out why I’m getting the following errors. My directory structure is:
.(helmfile.d)
├── generic
| ├── helmfile.yaml
│ ├── 01-secrets-management
│ │ ├── dex
│ │ │ ├── helmfile.yaml
│ │ │ └── values.yaml
│ │ ├── helmfile.yaml
│ │ ├── oauth2-proxy
│ │ │ ├── arm64-values.yaml
│ │ │ ├── secrets
│ │ │ ├── values.yaml
│ │ │ └── wait_for_endpoint.sh
│ │ ├── vault-operator
│ │ │ ├── helmfile.yaml
│ │ │ ├── secrets
│ │ │ │ └── vault-cr-secret-dec.yaml
│ │ │ └── values.yaml
│ │ └── vault-secrets-webhook
│ │ └── values.yaml
| └── common
│ ├── config.yaml
│ ├── environments.yaml
│ ├── helmdefaults.yaml
│ └── repos.yaml
└── helmfile.yaml
The helmfile.yaml
in .
is:
---
helmfiles:
- "*/*"
The helmfile.yaml
in generic
is:
helmfiles:
- "*"
The helmfile.yaml
in 01-secrets-management
is:
bases:
- ../common/environments.yaml
- ../common/repos.yaml
- ../common/helmdefaults.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
finally:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
The helmfile.yaml
in dex
is:
bases:
- ../../common/environments.yaml
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
## ************************************
## Start of DEX installation
## ************************************
releases:
- name: dex
namespace: {{ .Values.dex.namespace }}
createNamespace: true
labels:
tier: "secrets-management"
app: dex
chart: repo/helm-charts
version: {{ .Values.dex.version }}
values:
- values.yaml
I’m running helmfile -e default --log-level debug lint
from the dex
directory. I get the following output/error:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
The first error means that it’s not finding/using the common bases. I’m not understanding why. The last error is seemingly cascading from the first.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
perhaps I’ve misread/misunderstood the documentation on bases
but re-reading it it seems that helmfile
is trying to render helmfile.yaml
BEFORE rendering the other layers. Is that correct?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so if that’s the case then that means I can’t use anything defined in environments
because it’s not yet read/rendered. Correct?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
seems kinda useless to me if that’s the case.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
FTR, if this is how bases
works, it seems that it’s not very useful in this case and would be more useful in top-level helmfile.yaml
files.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
We can’t resolve that chicken-and-egg problem automagically. I may be still missing something but at glance what you wanted seems like
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
bases:
- ../../common/environments.yaml
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
---
## ************************************
## Start of DEX installation
## ************************************
releases:
- name: dex
namespace: {{ .Values.dex.namespace }}
createNamespace: true
labels:
tier: "secrets-management"
app: dex
chart: repo/helm-charts
version: {{ .Values.dex.version }}
values:
- values.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Notice ---
so that the first part is rendered as a template to produce a YAML structure that includes bases
. Bases should be loaded and the env values are loaded before rendering the latter part as a template
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ahh! Lemme give that a try real fast.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
nice!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
not outta the woods yet…but that got me past that roadblock
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
how much time you got @mumoshu? Is it late where you are? I have questions, thoughts, and possibly ideas.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and I’m still very new to helmfile so I’m struggling to get a good working set of helmfiles here.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
The error has changed…but I think this is good as it seems that the bases
files are getting read now. These are the new errors.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
This looks like possibly over-lapping values between my config.yaml
or environments.yaml
files.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
actually, this looks like it’s reading environments.yaml
which in turn references config.yaml
within the directory where environments.yaml
resides. This might be a referential problem with respect to … something.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes it does. probably https://sweetops.slack.com/archives/CE5NGCB9Q/p1618385513079000?thread_ts=1618381282.078300&cid=CE5NGCB9Q clarifies that a bit?
files referenced from within a sub-helmfile is relative to the sub-helmfile, to make the sub-helmfile portable(not dependent on the parent-helmfile)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
taking another look at https://github.com/roboll/helmfile#paths-overview
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so
Relative paths referenced in the Helmfile manifest itself are relative to that manifest
does this mean in sub-helmfile.yaml files that the path references in those files are relative to them or the relative to the top-level helmfile.yaml?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m trying to use paths in sub-files as relative to the sub-files.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
wow.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s the case.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu that’s a super-confusing thing methinks.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it’s also not very portable imo.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
why?(i’m not yet sure if I fully understand your usecase
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
files referenced from within a sub-helmfile is relative to the sub-helmfile, to make the sub-helmfile portable(not dependent on the parent-helmfile)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so to me the current behaviour makes sub-helmfiles portable, which is nice
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i need to learn something- what would be ideal behaviour and how would you rewrite your yamls with that ideal behaviour?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well, maybe I’m doing something wrong. So lemme articulate what I’m doing first and then I’ll attempt to explain what and why I’m doing it.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
first, I’m still trying to read through the docs and learn helmfile. The docs are good, but not very simple to follow referentially.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so, all the stuff I showed here is relevant
Good evening everyone. I’m trying to learn helmfile
and am struggling to figure out why I’m getting the following errors. My directory structure is:
.(helmfile.d)
├── generic
| ├── helmfile.yaml
│ ├── 01-secrets-management
│ │ ├── dex
│ │ │ ├── helmfile.yaml
│ │ │ └── values.yaml
│ │ ├── helmfile.yaml
│ │ ├── oauth2-proxy
│ │ │ ├── arm64-values.yaml
│ │ │ ├── secrets
│ │ │ ├── values.yaml
│ │ │ └── wait_for_endpoint.sh
│ │ ├── vault-operator
│ │ │ ├── helmfile.yaml
│ │ │ ├── secrets
│ │ │ │ └── vault-cr-secret-dec.yaml
│ │ │ └── values.yaml
│ │ └── vault-secrets-webhook
│ │ └── values.yaml
| └── common
│ ├── config.yaml
│ ├── environments.yaml
│ ├── helmdefaults.yaml
│ └── repos.yaml
└── helmfile.yaml
The helmfile.yaml
in .
is:
---
helmfiles:
- "*/*"
The helmfile.yaml
in generic
is:
helmfiles:
- "*"
The helmfile.yaml
in 01-secrets-management
is:
bases:
- ../common/environments.yaml
- ../common/repos.yaml
- ../common/helmdefaults.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and the way I’m approaching creating this is by trying to get helmfile to work in the dex release first. The ultimate goal, however, is to run helmfile from a different directory (one that references the environment I want to deploy).
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so, my thinking is, get it working first in dex
. Then get helmfile to work one directory up from dex
(01-secrets-management
)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
all the way up to generic
.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m trying to keep this DRY…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m not sure any of this makes sense. It’s difficult to articulate.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Sounds good so far
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh good
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, so, if I run helmfile
from dex
which uses the ../../common/environments.yaml
file to define environments.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the ../../common/environments.yaml
file references a file called config.yaml
but I’m in dex
so the reference to config.yaml
has to be referenced relatively from dex
but ../../common/environments.yaml
will need to be changed when I run helmfile
from a different directory.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s what I mean by “not very portable”
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it would be better if (at least in the way I’m using this) to relatively reference files from the manifest referencing the file.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
So, I’m in /var/tmp/helmfile-work/helmfile/helmfile.d/generic/01-secrets-management/dex
and ../../common/environments.yaml
contains:
environments:
default:
values:
- ../../common/config.yaml
production:
values:
- ../../common/config.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the ../../common/environments.yaml file references a file called config.yaml but I’m in dex so the reference to config.yaml has to be referenced relatively from dex but ../../common/environments.yaml will need to be changed when I run helmfile from a different directory. (edited)
ah gotcha!
fwiw, it doesn’t look like what bases
is supposed to help today.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the contents of common
is:
at 00:58:51 ❯ ls -ltr ../../common
total 16
-rw-rw-r-- 1 jimconn jimconn 540 Apr 13 00:02 repos.yaml
-rw-r--r-- 1 jimconn vboxsf 486 Apr 13 22:10 config.yaml
-rw-rw-r-- 1 jimconn jimconn 129 Apr 13 23:20 environments.yaml
-rw-rw-r-- 1 jimconn jimconn 37 Apr 13 23:26 helmdefaults.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I’m not using it properly?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I usually recommend using
{{ readFile "common.yaml.gotmpl" | tpl . $someData }}
---
# releases, repositories, etc
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I can give that a try in a moment
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
one more quick question then…something that’s not really documented very well I think
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I’m gonna switch gears on you for a min
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
this might be a really easy question for you to answer.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i thought there were opening issue(s) about adding parameters to bases
but i cant get the exact link urls for them now
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
all right, here’s the helmfile.yaml
again for dex
:
---
bases:
- ../../common/environments.yaml
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
---
## ************************************
## Start of DEX installation
## ************************************
releases:
- name: dex
namespace: {{ .Values.dex.namespace }}
createNamespace: true
labels:
tier: "secrets-management"
app: dex
chart: repo/dex
version: {{ .Values.dex.version }}
values:
- values.yaml.gotmpl
set:
- name: var.aws_nlb_with_tls_termination_at_lb
value: {{ env "AWS_NLB" | default false }}
- name: var.arm64_support
value: {{ env "ARM64" | default false }}
I’m trying to use a templatized values.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
my values.yaml.gotmpl
(partial) is:
# DO NOT increase replicas to >1 during the initial install.
# There is a bug which causes the GRPC TLS certs not to be issued because of webhook race conditions.
# Bug : <https://github.com/helm/charts/issues/24229>
#replicas: 3
{{- if var.arm64_support }}
image: ghcr.io/dexidp/dex
imageTag: "v2.26.0"
{{- end }}
tolerations:
- key: "dedicated"
operator: "Equal"
value: "utility"
effect: "NoSchedule"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I am not able to reference the set
parameters in the values.yaml.gotmpl
— not sure what I’m doing wrong here.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah well I haven’t really tried to use it that way but after rereading https://github.com/roboll/helmfile/issues/688
this might work:
values:
- someValuePassedToBases: "foobar"
---
bases:
- common.yaml
---
#releases, repositories, etc
Extracted from #347 (comment) We've introduced bases a month ago via #587. I'd like to make this breaking change(perhaps the first, intended breaking change in helmfile) before too many peo…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
values.yaml.gotmpl
is rendered by helmfile. you have access to helmfile-managed values only there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
where set
sets values passed to helm
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ahhh
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, so I need to set those in a helmfile
values somewhere. Maybe the thing you just linked?
values:
- key: "something"
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you usually use helmfile (environment) values to produce a series of set
entries and values
files
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
set
and values
entries rendered and merged by helmfile are passed to helm
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ok, so I need to set those in a helmfile values somewhere. Maybe the thing you just linked?
absolutely!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
right, so I’m trying to localize those to just dex in this case. Obviously, I’m not just going to use helmfile to deploy dex but it will be used to deploy a bunch of stuff. So, trying to find a way to make this work both “locally” (for just dex) and then from more of an environment deployment perspective is where I’m getting lost.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok! Let me think through how to do that.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
wishing your good luck!
let me also note that i believe it would worth trying https://sweetops.slack.com/archives/CE5NGCB9Q/p1618387448086400?thread_ts=1618381282.078300&cid=CE5NGCB9Q
ah well I haven’t really tried to use it that way but after rereading https://github.com/roboll/helmfile/issues/688
this might work:
values:
- someValuePassedToBases: "foobar"
---
bases:
- common.yaml
---
#releases, repositories, etc
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
helmfile is a rich ecosystem of stuff. Trying to wrap my head around it all for my use-case is complicated.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I appreciate your help!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
sounds right- keep posting comments/questions/feedbacks here. i or other people will respond soon!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
2021-04-14
2021-04-15
data:image/s3,"s3://crabby-images/19878/19878f14335ff8951cc92126f82d6805d5b7f629" alt="gonzalez.mariano.gabr avatar"
hey guys, im trying to add helmfile to a docker image (dockerfile) and not sure if https://github.com/roboll/helmfile/releases/download/v0.138.7/helmfile_linux_amd64 is the actual binary?
data:image/s3,"s3://crabby-images/a1c0f/a1c0f392cee61a2da37d311b1979734e43a44971" alt="Antoine Taillefer avatar"
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
can we set a “security” to avoid misdeploys? I mean if I accidentally deploy from a wrong branch to a cluster. ? a warning message or interactive promt… and not -i because we can forget it. in default config maybe?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I have the following directory structure where helmfile.d
has the helmfile manifests. The helmfile
directory tree has my environments and this is from where I want to invoke environmental helmfile runs:
├── helmfile
│ ├── envs
│ │ ├── dev
│ │ │ └── cluster-a
│ │ ├── preprod
│ │ └── production
│ └── shlib
└── helmfile.d
└── generic
├── 01a-network-and-proxies
│ ├── ambassador
│ ├── external-dns
│ └── ingress-nginx
├── 01b-secrets-management
│ ├── certmanager
│ ├── dex
│ ├── oauth2-proxy
│ │ └── secrets
│ ├── vault-operator
│ │ └── secrets
│ └── vault-secrets-webhook
└── common
In cluster-a
there’s a helmfile.yaml
and config.yaml
:
❯ \cat helmfile.yaml
environments:
default:
values:
- config.yaml
helmfiles:
- "../../../../helmfiles.d/*"
The concept is that any specific configuration values for cluster-a
are specified in the config.yaml
inside the cluster-a
directory. However, when I test invoking helmfile
from this path, I get the error:
envvals_loader: loaded config.yaml:map[values:map[keyname:foobar]]
no matches for path: ../../../../helmfiles.d/*
merged environment: &{default map[values:map[keyname:foobar]] map[]}
helm:XVlBz> v3.4.1+gc4e7485
0 release(s) found in helmfile.yaml
err: no releases found that matches specified selector() and environment(default), in any helmfile
I don’t understand why.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
one thing to note is there’s a helmfile.yaml
in each directory which specifies helmfiles
property:
.(helmfile.d)
├── generic
│ ├── 01a-network-and-proxies
│ │ └── helmfile.yaml
│ ├── 01b-secrets-management
│ │ └── helmfile.yaml
│ └── helmfile.yaml
└── helmfile.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
in helmfile.d/helmfile.yaml
---
helmfiles:
- "generic/*"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
in generic/helmfile.yaml
helmfiles:
- "*/*.yaml"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
won’t the attribute in helmfiles:
cause helmfile to “walk up the chain” so-to-speak?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sigh, figured it out.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
for posterity sake, the helmfile.yaml
in the cluster-a
directory had a misspelled directory name: - "../../../../helmfiles.d/*"
(note helmfiles.d vs helmfile.d)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu https://github.com/roboll/helmfile/issues/1045#issuecomment-820870785 might be interesting to you?
I've been trying to use environments in my main helmfile and have multiple sub helmfiles in my releases folder. I wanted all the sub helmfiles to pick up whatever the value I defined in a speci…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sigh. I’m really struggling to understand certain points in this documentation. I keep getting blocked on aspects of how to properly use helmfile
and I either can’t find documentation to meet my needs or the documentation I think will help me either doesn’t make sense or is not as verbose as necessary to understand the full aspect of what the documentation is trying to point out.
For instance, I’m blocked on certain aspects of this project (tickets and questions are submitted) and I’m moving on to other aspects of this project where I’m not blocked. One of those aspects is the ability to logically select charts. It doesn’t work the way I’m trying to implement so I’m reading the documentation, which doesn’t make sense to me. I don’t understand the context of inheritance with respect to sub-helmfiles and the inherited properties. That point is not well spelled out. What do you mean by inherited in context? Everything? Certain properties? The selectors? I don’t understand.
The use-case I’m trying to solve is to simply use a selector to run helmfiles only identified by that selector. Everything will run exactly the same as if I didn’t use any selector except ONLY the helmfiles specified by that selector (or a negated selector) would run. The details of how that works should not be something the end-user is concerned about if it’s clear-cut as what I was hoping would be the case. I’m simply not understanding, which I think is because the documentation is a little too sparse, but there is a lot of documentation. I can’t put my finger on the problem. It might be me, which I can concede. It shouldn’t be this complicated to understand what software can do and I keep running into roadblocks here. I want to use helmfile because I believe it does what we need it to do. Some assistance would be greatly appreciated.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
inherited in context?
Hey! Helmfile doesn’t inherit anything to sub-helmfiles. Inheritance of helmfile environments and values usually happen only between the parent helmfile.yaml and bases. Does that clarify it a bit?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
That’s also the foundational thing under my comment on your previous question https://github.com/roboll/helmfile/issues/1045#issuecomment-821910447
I've been trying to use environments in my main helmfile and have multiple sub helmfiles in my releases folder. I wanted all the sub helmfiles to pick up whatever the value I defined in a speci…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Selectors aren’t inherited. It’s just that the user specifies the selector and helmfile uses it to filter releases across all the involved helmfie.yaml.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Environment and environment values aren’t inherited. That’s why this doesn’t work:
environments:
default:
values:
- config.yaml
---
helmfiles:
- "../../../../helmfile.d/"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
The documentation may be outdated or incomplete or simply incorrect, seeing your frustration.
Did you find any specific documentation saying that environments and values are inherited down to sub-helmfiles? If so, we’d definitely need to fix it.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Does the documentation say if anything’s inherited to sub-helfmiles or bases?
I thought I even didn’t explicitly say in the documentation that the bases inherit parent’s environments and values, as trying to depend on the parent helmfile.yaml always sounded like a bad idea to me.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Everything will run exactly the same as if I didn’t use any selector except ONLY the helmfiles specified by that selector (or a negated selector) would run.
--selector
(-l
) works that way. To do so, Helmfile requires you to make each sub-helmfile independently consumable. That’s why environments arent inherited down to sub-helmfiles, and the basis of comments starting from https://sweetops.slack.com/archives/CE5NGCB9Q/p1618707461115400?thread_ts=1618551534.114100&cid=CE5NGCB9Q
inherited in context?
Hey! Helmfile doesn’t inherit anything to sub-helmfiles. Inheritance of helmfile environments and values usually happen only between the parent helmfile.yaml and bases. Does that clarify it a bit?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Would there be anything I’ve not yet answered?
data:image/s3,"s3://crabby-images/52424/52424d33680858783f898fedfba442656a2ec09a" alt="vicken avatar"
Hey @mumoshu also have a selector question, are there maybe reserved words helmfile doesn’t allow to be label selectors?
Consider a simple example with 3 labels in 2 releases:
repositories:
- name: datawire
url: <https://www.getambassador.io>
- name: incubator
url: <https://charts.helm.sh/incubator>
releases:
- name: ambassador
namespace: ambassador
labels:
chart: ambassador
namespace: ambassador
foo: bar
chart: datawire/ambassador
version: 6.6.2
- name: raw
namespace: ambassador
labels:
chart: ambassador
namespace: ambassador
foo: bar
chart: incubator/raw
version: 0.2.5
If I run helmfile -l namespace=ambassador diff
both releases are selected in the diff
If I run helmfile -l foo=bar diff
both releases are selected in the diff
However, if i run helmfile -l chart=ambassador diff
only the first release is selected in the diff. This is on v0.138.6.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Yes. As far as I remeber, chart
and name
are reserved, each has the respective value of the release
data:image/s3,"s3://crabby-images/52424/52424d33680858783f898fedfba442656a2ec09a" alt="vicken avatar"
hah, thank you! it was confusing me for the longest time (why some releases weren’t being applied)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Ah, that makes sense! Probably we’d better enhance the docs to note about reserved labels and make it a validation error when you’ve tried to override a reserved label
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Would you mind opening issues?
data:image/s3,"s3://crabby-images/52424/52424d33680858783f898fedfba442656a2ec09a" alt="vicken avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Thank you for the response @mumoshu! Today is my Sunday and I have other obligations today but I will answer your questions here tomorrow and also your comment for my GH issue! Very much appreciated!
data:image/s3,"s3://crabby-images/99f14/99f142c769556c4d75482d90487388acdad54bf3" alt="cool-doge"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu I updated my comments in the GH issue
I've been trying to use environments in my main helmfile and have multiple sub helmfiles in my releases folder. I wanted all the sub helmfiles to pick up whatever the value I defined in a speci…
2021-04-16
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
Do I have to explicitly define a reference to each of the values I include under a named environment block into a release or is there a tidier way to bulk include the contents of the environment block ontop of the release values?
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
I feel daunted compared to Jim’s previous question ;) but I managed to break this down to a simple example and suspect i’m just “doing helmfile wrong” though the environments block in the README implies to me that this should work?
basically, i did helm create my-chart
and then wrote this helmfile.yaml for it.
environments:
dev:
values:
- fullnameOverride: my-chart-dev
live:
values:
- fullnameOverride: my-chart-live
releases:
- name: my-chart
chart: ../.
namespace: chart-test
version: 0.1.0
# values:
# - fullnameOverride: {{ .Values.fullnameOverride }}
so helmfile should deploy my chart where the full name for objects is overridden by the environment specific value.
however, helmfile doesn’t inherit those values unless I uncomment the last two lines and explicitly declare each variable I want to make environmentally conditional? Are all the environment values not inherited? I’m hoping to not have to write out each variable in the releases block otherwise I might as well go for the - ./ values/{{ environment.Name }}.yaml
method and I wanted to avoid having two full copies of the values.yaml..?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@jedineeper Hey! Well, honestly speaking I don’t understand how the documentation can make you think that environment values are inherited to release values. Probably the documentation needs to specifically say it doesnt?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Environment values are used to render helmfile.yaml templates and helmfile’s values gotmpl files only.
Helmfile doesn’t automatically pass those values to Helm(as release values).
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/52424/52424d33680858783f898fedfba442656a2ec09a" alt="vicken avatar"
Uncommenting the last two lines is the way I understand using helmfile with environments.
That the usage of {{ .Values.fullnameOverride }}
in the chart files and the usage of {{ .Values.fullnameOverride }}
in helmfile refer to separate things.
Inside the chart, .Values
refer to the helmchart release’s values:
metadata:
labels:
foo: {{ .Values.fullnameOverride }}
refers to this value:
releases:
- name: my-chart
chart: ../.
namespace: chart-test
version: 0.1.0
values:
- fullnameOverride: bar
So the label foo=bar.
Inside the helmfile, .Values
refer to the environment’s values:
releases:
- name: my-chart
chart: ../.
namespace: chart-test
version: 0.1.0
values:
- fullnameOverride: {{ .Values.fullnameOverride }}
refers to these values:
environments:
dev:
values:
- fullnameOverride: my-chart-dev
live:
values:
- fullnameOverride: my-chart-live
and you have to select between them with the -e
environment argument.
The last two lines bridge the two cases together.
data:image/s3,"s3://crabby-images/99f14/99f142c769556c4d75482d90487388acdad54bf3" alt="cool-doge"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@jedineeper If you want to have different “helm” values.yaml per each helmfile named environment, I’d do this:
environments:
dev: {}
live: {}
---
releases:
- name: my-chart
chart: ../.
namespace: chart-test
version: 0.1.0
values:
- environments/{{ .Environment.Name }}/values.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@vicken Great explanation!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
We can even merge the above examples:
---
environments:
dev:
values:
- fullnameOverride: my-chart-dev
live:
values:
- fullnameOverride: my-chart-live
---
releases:
- name: my-chart
chart: ../.
namespace: chart-test
version: 0.1.0
values:
- environments/{{ .Environment.Name }}/values.yaml
- fullnameOverride: {{ .Values.fullnameOverride }}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
A common addition to this is when you’d like to make the environment-specific helm values.yaml optional, add missingFileHandler
:
environments:
dev:
values:
- fullnameOverride: my-chart-dev
live:
values:
- fullnameOverride: my-chart-live
---
releases:
- name: my-chart
chart: ../.
namespace: chart-test
version: 0.1.0
missingFileHandler: Warn
values:
- environments/{{ .Environment.Name }}/values.yaml
- fullnameOverride: {{ .Values.fullnameOverride }}
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
Super useful, thanks both. Looks like I was on the wrong track with my understanding and that’s cleared up now :)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu this might help me. I’d still like to read your thoughts outlined in my gh issue but I might be able to make progress with this information.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Jim Conner In the scenario 3, are you trying to feed environments defined in bluescape/ops/helmfile-project/helmfile/envs/dev/cluster-n/config.yaml
into every helmfile yamls defined under bluescape/ops/helmfile-project/helmfile.d
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
This was where I was getting confused with the concept of inheritance in trying to understand what inheritance was with respect to helmfile
though you corrected me in one of your responses that helmfile
doesn’t inherit. So, let’s not use that term, but I am trying to propagate the values defined in config.yaml
in scenario three across the board of whatever I deploy using helmfile
from any respective environment directory
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
It’s much better to treat there’s no inheritance, I think. (Where did you find helmfile does inheritance? I think that doc should be corrected if it’s confusing
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Gotcha so
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
It’s documentation that I read in other github issues…not in your documentation
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Thx I see! Firstly I’d repeat https://github.com/roboll/helmfile/issues/1045#issuecomment-821910447 - envs defined in config.yaml doesn’t get automatically passed to sub-helmfiles under helmfile.d
.
I guess this should work:
helmfiles:
- path: "../../../../helmfile.d/"
values:
- {{ .Values | toYaml | nindent 6 }}
I've been trying to use environments in my main helmfile and have multiple sub helmfiles in my releases folder. I wanted all the sub helmfiles to pick up whatever the value I defined in a speci…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Lemme give that a try…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
taking a read real fast.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I admit this isn’t elengant, but not sure if there’s any better way than this now..
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok. Lemme take a look.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Lemme ask you this…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
is the method of how I want to use helmfile
odd or something?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
It seems logical to me…and helmfile
is a very flexible tool, but am I doing it wrong?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Yours seem totally valid
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Ok, that’s good to know!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I guess it’s just that no one has ever (loudly) tried to do it in a such elegant way
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Wow. Thank you for that comment. Very nice.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I believe Helmfile should add something like the below to better support your usecase(actually this was my original plan was no one has ever requested it or sent me any question that leads to this
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so, it seems like it could potentially be complicated to code depending on the library(ies) you might be using to mux objects…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but if you have a solid top-level then inheritance probably isn’t that tough to enable.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
taking a look at this now…gimme a few please.
I've been trying to use environments in my main helmfile and have multiple sub helmfiles in my releases folder. I wanted all the sub helmfiles to pick up whatever the value I defined in a speci…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
So from your comment in the thread, it’s not very clear to me which helmfile.yaml
that you are suggesting change to.
also, do you see merit in making a feature request out of this use-case? I’d LOVE to see this functionality.
I've been trying to use environments in my main helmfile and have multiple sub helmfiles in my releases folder. I wanted all the sub helmfiles to pick up whatever the value I defined in a speci…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
also, in that thread, I need to define the config.yaml
which has the values defined in the top-level directory but it seems your example only defines a scriptsDir
which I suppose is the defined directory where the top-level config.yaml
file would reside; but if I point the scriptsDir
to the same path as where my top-level is then it seems that would cause a circular dependency unless I can specifically say, “use this file” — not just “use this directory”
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu is there a way to get helmfile template --selector foo=bar
to work?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if I point the scriptsDir to the same path as where my top-level is then it seems that would cause a circular dependency
This wasn’t clear to me, circular dependency between what, do you mean?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Jim Conner Did you literally mean the way? You need to place --selector foo=bar
before template
.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, lemme check that out.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah perfect! Thank you
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it’s not very clear to me which helmfile.yaml that you are suggesting change to.
I meant helmfile/envs/dev/cluster-a/helmfile.yaml
, assuming that’s where you’re trying to say “inherit envs defined in config.yaml to ../../../../helmfile.d/”
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah! Ok. So scriptsDir
points to the top-level directory?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Ah, no. It’s just an arbitrary value for illustration purpose.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
It is’nt a reserved value in any way so you can’t assume scriptsDir points to anywhere wihout you specifically set it
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
k, so right now, the following seems to be working but I’m still attempting to test (this is my top-level):
environments:
default: {}
---
helmfiles:
- path: "../../../../helmfile.d/"
values:
- config.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I don’t have all of the sub-helmfile.yaml manifests completely correct yet, except for dex but unfortunately, my selector is not working.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I’m trying to figure that out.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
0 release(s) matching tier=secrets-management,app=dex found in helmfile.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
have you tried helmfile --debug $SUBCOMMAND
? it would print a lot of logs to help debugging
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yup
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m reading through it all now to see if I can figure out where my problem lies
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
funny enough, the error I just posted is exactly after the repo updates. So, gotta figure it out.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
0 release(s) matching tier=secrets-management,app=dex found in helmfile.yaml
will be printed on any sub-helmfile that contain other releases. But I thought it doesn’t result in an error?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I mean, you’ll see 0 release(s) matching tier=secrets-management,app=dex found in helmfile.yaml
in debug logs on every sub-helmfile that didn’t have releases matching the selector. But Helmfile won’t fail when any sub-helmfile had one or more releases that matched.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just a sec. still reading through the output. I found out that I had --selector
specified twice on accident on the command line so that was one problem.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the problem seems to be that helmfile
is not traversing recursively into certain paths…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
could you push your project in github so that i can reproduce?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sure!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
gimme a sec.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sorry for taking so long. Wife was in here talking to me for a min. Now, I’m scrubbing the repo as it’s not open source, but there’s nothing of great value in here yet. So, I’ll create in my personal repo temporarily and provide you with the link.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
My shell stuffs. Contribute to notjames/jimconn-shell development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I removed secrets files, so if you run this and you get errors about that, that’s why
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Thanks!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just a sec
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
need to do something
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the problem seems to be that helmfile is not traversing recursively into certain paths…
what were certain paths
and what helmfile command did you run to see it?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
do a pull real fast
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and then cd <repo>/temp/helmfile/envs/dev/atreus
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
done
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
thx
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
now in that directory I ran: helmfile --debug --selector app=dex template
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
err: error during helmfile.yaml.part.0 parsing: template: stringTemplate:5:30: executing "stringTemplate" at <.Environment.Values.namespace>: map has no entry for key "namespace"
changing working directory back to "/home/mumoshu/p/jimconn-shell/temp/helmfile.d/generic/01a-network-and-proxies"
changing working directory back to "/home/mumoshu/p/jimconn-shell/temp/helmfile.d"
changing working directory back to "/home/mumoshu/p/jimconn-shell/temp/helmfile/envs/dev/atreus"
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[0]: in generic/01a-network-and-proxies/helmfile.yaml: in .helmfiles[1]: in external-dns/helmfile.yaml: error during helmfile.yaml.part.0 parsing: template: stringTemplate:5:30: executing "stringTemplate" at <.Environment.Values.namespace>: map has no entry for key "namespace"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
when you run that, you’ll notice that helmfile
doesn’t backup the tree after descending into 01a-…
to traverse into 01b-…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ahh…you’re saying that the reason is because the external-dns
“chart” is broken….that makes sense.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ll fix real fast. I haven’t polished all of these yet so I’m not concerned about that being broken
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems so! helmfile traverses sub-helmfile in some alphabetical order and fail-fast
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah!! OK, that’s good to know
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lemme fix that real fsat.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
does helmfile
descend into dot directories?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
nm. I’ll rm -rf
external-dns and ingress-nginx
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
haven’t tried that but as long as the exact path or a glob pattern that matches the dotted directory/file, it should just work (I thought I have not programmed helmfile to explicitly ignore dot dir/file
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
all right, so the error I’m getting now is:
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[0]: in generic/01a-network-and-proxies/helmfile.yaml: in .helmfiles[1]: in ambassador/helmfile.yaml: [Malformed label: tier="network-and-proxies". Expected label in form k=v or k!=v]
That tier
is defined in generic/01a-network-and-proxies/helmfile.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so that’s interesting
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the idea was, I can specify a tier at a higher level in the directory structure…but I wasn’t sure that would work.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
maybe I did something wrong in the helmfile, though
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the error seems to state as much
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah, I see
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems like you tried to use "
in the selector which isn’t supported?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well, I tried using proper yaml first. That fails.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just tried it again.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
first-pass produced: &{default map[] map[]}
first-pass rendering result of "helmfile.yaml.part.0": {default map[] map[]}
second-pass rendering result of "helmfile.yaml.part.0":
0: helmfiles:
1: - "*/helmfile.yaml"
2: - path: */helmfile.yaml
3: selectors:
4: - tier=secrets-managment. <<== apparently not OK
5
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
❯ \cat helmfile.yaml
helmfiles:
- "*/helmfile.yaml"
- path: "*/helmfile.yaml"
selectors:
- tier: network-and-proxies
gives:
n ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[0]: in generic/01a-network-and-proxies/helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: unmarshal errors:
line 5: cannot unmarshal !!map into string
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
needs to be tier=network-and-proxies
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
is selectors:
requiring a list perhaps?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
definitely!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
k, lemme fix and try
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it must be a lint of strings
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
with no "
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
in where?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
as long as it’s a yaml string, it would be okay
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
- "foo=bar"
works
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, lemme try
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
- foo="bar"
is a valid string but invalid in terms of the selector syntax
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so
❯ \cat helmfile.yaml
helmfiles:
- "*/helmfile.yaml"
- path: "*/helmfile.yaml"
selectors:
- "tier=network-and-proxies"
and this is temp/helmfile.d/generic/01a-network-and-proxies/helmfile.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems good
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
OK cool; that error is gone. But now it still can’t find the selector.
merged environment: &{default map[ambassador:map[namespace:ambassador version:6.6.2] arm64_support:false aws_nlb_with_tls_termination_at_lb:false blscauxclusterissuer:map[namespace:certmanager version:0.1.0] certmanager:map[namespace:certmanager version:1.0.4] cluster_id:<nil> dex:map[namespace:dex version:2.15.2] domain_name:<nil> externaldns:map[namespace:externaldns version:v20210203-v0.7.6-28-g44288212-arm64v8] name:somename nginxingress:map[namespace:ingress-nginx version:3.15.2] oauth2proxy:map[namespace:auth-system version:3.2.5] postgres:map[namespace:grafana version:x.x.x] semver:0.0.1 vaultoperator:map[namespace:vault version:1.8.1] vaultsecretswebhook:map[namespace:secrets-webhook version:1.8.2]] map[]}
0 release(s) matching tier=network-and-proxies found in helmfile.yaml
changing working directory back to "/home/jimconn/projects/src/personal/jimconn-shell/temp/helmfile.d/generic/01a-network-and-proxies"
0 release(s) matching app=dex found in helmfile.yaml
err: no releases found that matches specified selector(app=dex) and environment(default), in any helmfile
hmm….
is helmfile
looking at the labels in releases:
object too or just helmfile objects?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
what’s the command now? I’m pretty lost
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
mumoshu@m75q2a:~/p/jimconn-shell/temp/helmfile.d/generic/01a-network-and-proxies$ $HOME/p/helmfile/helmfile template
Adding repo datawire <https://www.getambassador.io>
"datawire" has been added to your repositories
in ./helmfile.yaml: in .helmfiles[0]: in ambassador/helmfile.yaml: failed to render values files "values.yaml.gotmpl": failed to render [values.yaml.gotmpl], because of template: stringTemplate:63:20: executing "stringTemplate" at <.Values.resources.limits.cpu>: map has no entry for key "resources"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
is helmfile looking at the labels in releases: object too or just helmfile objects?
i don’t get it. helmfile “object” doesn’t have labels. only releases have labels to be matched by selectors
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lol. I’m sorry. So the command is being run from temp/helmfile/envs/dev/atreus
and the command I’m using is: helmfile --debug --selector app=dex template
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
if you notice that I was able to provide a selector
in the helmfiles
object of a helmfile.yaml
for 01a-…
and that at least linted.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep. that means you’re letting helmfile to run helmfile -l $SELECTOR_HERE template
on the sub-helmfile
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yup
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that way, helmfile uses the selector to filter releases defined in the sub-helmfile
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
cool
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I was thinking that I could also use a selector for a specific helm release given a selector
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so in other words, let’s say I’m in my cluster-a
environment
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that should work
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
all I want to do is release one single app
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I name all my apps in releases
with a selector (which I know this is a helm selector but helmfile
seems to understand those, right)?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the point is that no helmfile.yaml under helmfile.d/generic/01a-network-and-proxies/*
has releases that have the label app: dex
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh sure! I know. It’s in 01b-security-management/dex
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i see! then you need to provide that to helmfile.yaml. currently it doesn’t refer to it
$ cat helmfile.yaml
helmfiles:
- "*/helmfile.yaml"
- path: "*/helmfile.yaml"
selectors:
- tier=network-and-proxies
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
my dex
helmfile bundle is done so I’m just testing the “e2e” from cluster-a
(or atreus) to see if my top-level config works.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
were you trying to say this?
helmfiles:
- "../*/helmfile.yaml"
- path: "*/helmfile.yaml"
selectors:
- tier=network-and-proxies
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well, no
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ok. but you need to add e.g. 01b-security-management/dex
to helmfiles
section at least
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
k. just a sec. Lemme see
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so in my 01b-security-manangement
helmfile.yaml
I have:
helmfiles:
- "*/helmfile.yaml"
- path: */helmfile.yaml
selectors:
- tier=secrets-managment
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I was thinking that if I place a selector on the command line the helmfile
will read everything and simply use anything found matching the requested selector
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep you seem to be correct
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and in this case, I have a bundle named dex
which only deploys dex and it’s under 01b-security-management/dex
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and the helmfile.yaml
in there is:
---
bases:
- ../../common/environments.yaml
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
---
releases:
- name: dex
namespace: {{ .Values.dex.namespace }}
createNamespace: true
labels:
app: dex <<<<<=== THERE
chart: stable/dex
version: {{ .Values.dex.version }}
values:
- values.yaml.gotmpl
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so helmfile
should find that right?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep. but where are you running helmfile from?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the atreus
directory
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and the content of helmfile.yaml under atreus
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh, lemme post it
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
environments:
default: {}
---
helmfiles:
- path: "../../../../helmfile.d/"
values:
- config.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so helmfile should read the helmfile.yaml
in helmfile.d
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
which only matches all *.yaml files in every directory
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that directory contains the 01a-…
and 01b-…
directories which have helmfile.yaml
files which define a tier selector for that directory of bundles.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so this is what im getting
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
mumoshu@m75q2a:~/p/jimconn-shell/temp/helmfile/envs/dev/atreus$ $HOME/p/helmfile/helmfile -l app=dex template
Adding repo stable <https://charts.helm.sh/stable>
"stable" has been added to your repositories
Adding repo jetstack <https://charts.jetstack.io>
"jetstack" has been added to your repositories
Adding repo bitnami <https://charts.bitnami.com/bitnami>
"bitnami" has been added to your repositories
Adding repo prometheus <https://prometheus-community.github.io/helm-charts>
"prometheus" has been added to your repositories
Adding repo banzaicloud-stable <https://kubernetes-charts.banzaicloud.com>
"banzaicloud-stable" has been added to your repositories
Adding repo cloudposse <https://charts.cloudposse.com/incubator/>
"cloudposse" has been added to your repositories
Adding repo datawire <https://www.getambassador.io>
"datawire" has been added to your repositories
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[1]: in generic/01b-secrets-management/helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: line 3: did not find expected alphabetic or numeric character
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
isn’t this due to that helmfile failing fast due to that it failed to parse generic/01b-secrets-management/helmfile.yaml
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
huh. werid.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
seems like it. I don’t get that though. Lemme commit/push what I have here and you can run it again and see if you get the same result.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
go ahead and pull
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i think you’d need to fix each helmfile.yaml to work alone
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh crap
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I am getting that
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I did that first.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but I might have changed something during all this. Lemme check that real fast.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
at glance this is invalid yaml
$ cat ../../../../helmfile.d/generic/01b-secrets-management/helmfile.yaml
helmfiles:
- "*/helmfile.yaml"
- path: */helmfile.yaml
selectors:
- tier=secrets-managment
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
should be
helmfiles:
- "*/helmfile.yaml"
- path: "*/helmfile.yaml"
selectors:
- tier=secrets-managment
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ll add the quotes.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
awesome!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that seemed to work
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ish
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
great
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
err: failed to read environments.yaml: environment values file matching "../../common/versions.yaml" does not exist in "."
changing working directory back to "/home/jimconn/projects/src/personal/jimconn-shell/temp/helmfile.d"
changing working directory back to "/home/jimconn/projects/src/personal/jimconn-shell/temp/helmfile/envs/dev/atreus"
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[2]: in generic/common/environments.yaml: failed to read environments.yaml: environment values file matching "../../common/versions.yaml" does not exist in "."
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, so that is an interesting error that I’m still fuzzy on in terms of the cause.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
this goes back to part of the conversation we had last week with respect to paths…but I still can’t articulate that very well, so I could just be wrong about its implementation
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well lets start reading it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
assuming we’re running helmfile-template in atreus
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[2]: in generic/common/environments.yaml: failed to read environments.yaml: environment values file matching "../../common/versions.yaml" does not exist in "."
means that
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
atreus/helmfile.yaml
loaded ../../../../helmfile.d/helmfile.yaml
, which in turn loaded generic/common/environments.yaml
.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
while helmfile’s trying to process the last file, environemnts.yaml
, it failed to find ../../common/versions.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
let’s see what’s in environments.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
---
environments:
default:
values:
- ../../common/versions.yaml
- ../../common/values.yaml.gotmpl
production:
values:
- ../../common/versions.yaml
- ../../common/values.yaml.gotmpl
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
$ cat ../../../../helmfile.d/generic/common/environments.yaml
---
environments:
default:
values:
- ../../common/versions.yaml
- ../../common/values.yaml.gotmpl
production:
values:
- ../../common/versions.yaml
- ../../common/values.yaml.gotmpl
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and this was where I was super confused
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
because it should have been values.yaml.gotmpl
and versions.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but that didn’t work
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
this was why I asked you the question the other day…if you will recall.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the paths
document says that helmfile will use paths relative to the yaml
file requesting the path/file
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
as you’re including it into some helmfile yaml under generic
, those paths should be releative to generic
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
this my finding is that this isn’t consistent
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that applies only to helmfile.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
which confused the poo outta me
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ahhh
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that makes more sense as far as what the documentation means
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so bases are base configuration or some form of skeleton of your helmfile.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so what about other manifests? How do paths work with respect to others?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if bases are evaluated in the directory of the base helmfile yaml, it would prevent you from reusing it in any useful way
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so every path is relative to the helmfile.yaml being processed
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah. hmm
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
bases modifies the helmfile.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so that might be problematic for how I’m trying to do this.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
probably. so you want to use base
to codify some convention of where each helmfile.yaml
should locate environment values files, right?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it worked nicely if I could make reference to these files relative to the manifest that references files.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and so…it might be a little easier than that
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and you wanted all the environment values files to be shared across all the helmfile.yaml files, right?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
basically yes
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
essentially, the way I’m doing this, everything is using the same files whether it’s running as individual releases, directory releases, or environment releases.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
lastly, do you want values.yaml.gtoml
and versions.yaml
to be under the same directory as environments.yaml
(base)?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes as those are basically global settings for everything but I want to be able to redefine stuff set in those (specifically the stuff in values.yaml.gotmpl) with the config.yaml
in cluster-n
environments.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and you seem to be using the base environments.yaml
from helmfile.yaml files in various levels
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
generic/01a-network-and-proxies/ambassador
is trying to load generic/common/environments.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes, because that’s a common
file — is how I’m using it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well it isn’t how base
is supposed to be used but i can see how you’d like to use it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
some people want to use bases
to be evaluated in the context of the helmfile.yaml
loaded it so helmfile is currently designed aroud that
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah…which I think I wanted to do it this way because it makes sense to me in terms of a structure. Set up a default set and then allow the ability for that default set to change based on overriding configurations
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
can you just embed all the values directly into environments.yaml
then?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
what’s an example of what that looks like?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
something like
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
templates:
values: &values
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
certmanager:
version: 1.0.4
namespace: certmanager
blscauxclusterissuer:
version: 0.1.0
namespace: certmanager
externaldns:
version: v20210203-v0.7.6-28-g44288212-arm64v8
namespace: externaldns
nginxingress:
version: 3.15.2
namespace: ingress-nginx
postgres:
version: x.x.x
namespace: grafana
oauth2proxy:
version: 3.2.5
namespace: auth-system
dex:
version: 2.15.2
namespace: dex
vaultoperator:
version: 1.8.1
namespace: vault
vaultsecretswebhook:
version: 1.8.2
namespace: secrets-webhook
environments:
default:
values:
- *values
production:
values:
- *values
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ahhh. I see… this might be doable.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well i used wrong term in the example but you get what i meant..
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
afk ill post compelte example later
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, use the yaml reference capability in conjunction with a template
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so i think this should work
templates:
versions: &versions
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
certmanager:
version: 1.0.4
namespace: certmanager
blscauxclusterissuer:
version: 0.1.0
namespace: certmanager
externaldns:
version: v20210203-v0.7.6-28-g44288212-arm64v8
namespace: externaldns
nginxingress:
version: 3.15.2
namespace: ingress-nginx
postgres:
version: x.x.x
namespace: grafana
oauth2proxy:
version: 3.2.5
namespace: auth-system
dex:
version: 2.15.2
namespace: dex
vaultoperator:
version: 1.8.1
namespace: vault
vaultsecretswebhook:
version: 1.8.2
namespace: secrets-webhook
values: *values
aws_nlb_with_tls_termination_at_lb: {{ .Values | get "aws_nlb_with_tls_termination_at_lb" false }}
arm64_support: {{ .Values | get "arm64_support" false }}
domain_name: {{ .Values | get "domain_name" (env "DOMAIN_NAME") }}
cluster_id: {{ .Values | get "cluster_id" (env "CLUSTER_ID") }}
---
environments:
default:
values:
- *versions
- *values
production:
values:
- *versions
- *values
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ugh. I just tried validating the configuration of the template test run I did a while ago (I had to re-establish the values.yaml.gotmpl contents, which I removed from my private repo) and unfortunately, I’m observing that the template run shows that the settings in the config.yaml
values in atreus
are not getting asserted during the template run meaning it seems that the helmfile.yaml
isn’t asserting the config from the top-level. :(
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lemme try your suggestion real fast though.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I’m observing that the template run shows that the settings in the config.yaml values in atreus are not getting asserted during the template run meaning it seems that the helmfile.yaml isn’t asserting the config from the top-level.
what do you mean by “asserting” here?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
are you saying that values defined in config.yaml
in the below atreus/helmfile.yaml
is not accessible from within sub-helmfiles ../../../.../helmfile.d
?
environments:
default: {}
---
helmfiles:
- path: "../../../../helmfile.d/"
values:
- config.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i have not yet fully understood your whole config, but from what i can guess from our conversation so far
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, seems so.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you may be missing to pass values in the middle
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh! I need to pass values?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
is there a generic way to do that without having to specify every variable?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Yes. As I have said in elsewhere, you must always explicitly pass values to sub-helmfiles
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ahhhh….
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
hence, no inheritance which you mentioned
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yeah
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so what works today is https://sweetops.slack.com/archives/CE5NGCB9Q/p1618896775125900?thread_ts=1618580632.114500&cid=CE5NGCB9Q
Thx I see! Firstly I’d repeat https://github.com/roboll/helmfile/issues/1045#issuecomment-821910447 - envs defined in config.yaml doesn’t get automatically passed to sub-helmfiles under helmfile.d
.
I guess this should work:
helmfiles:
- path: "../../../../helmfile.d/"
values:
- {{ .Values | toYaml | nindent 6 }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lemme give that a quick try, too
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and what we’ll likely to add to helmfile in (near) future https://sweetops.slack.com/archives/CE5NGCB9Q/p1618896996128700?thread_ts=1618580632.114500&cid=CE5NGCB9Q
helmfiles:
- path: "../../../../helmfile.d/"
inheritValues: true
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
got it!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
one sec
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
beware the number you pass to nindent
function. it’s dependent on the context.
- {{ .Values | toYaml | indent 2
- {{ .Values | toYaml | indent 4 }}
make sense, but
- {{ .Values | toYaml | indent 2 }}
or
- {{ .Values | toYaml | indent 4 }}
doesn’t.
this usage of toYaml with nindent is a common trick seen in wirting helm charts but I thought ir worth being explained
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
in my case, the indent is the same for all of the files and 6 is accurate I believe.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
first-pass produced: &{default map[values:[map[aws_nlb_with_tls_termination_at_lb:false] map[arm64_support:false] map[domain_<name:atreus.dev.domain.io>] map[cluster_id:atreus]]] map[]}
first-pass rendering result of "helmfile.yaml.part.0": {default map[values:[map[aws_nlb_with_tls_termination_at_lb:false] map[arm64_support:false] map[domain_<name:atreus.dev.domain.io>] map[cluster_id:atreus]]] map[]}
second-pass rendering result of "helmfile.yaml.part.0":
0: ---
1: helmfiles:
2: - "generic/*"
3: - path: "generic/*"
4: values:
5: -
6: values:
7: - aws_nlb_with_tls_termination_at_lb: false
8: - arm64_support: false
9: - domain_name: atreus.dev.domain.io
10: - cluster_id: atreus
11:
12:
err: failed to read helmfile.yaml: reading document at index 1: yaml: line 6: did not find expected node content
changing working directory back to "/project/helmfile-project/helmfile/envs/dev/atreus"
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: line 6: did not find expected node content
So the failure seems to be coming from the line I just added (helmfile.d/helmfile.yaml
---
helmfiles:
- "generic/*"
- path: "generic/*"
values:
- {{ .Values | toYaml | nindent 6 }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it’s not dereferencing .Values
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh wait
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it is
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I need to fix the config.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just a sec
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i’m now counting the size of the indentation there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
oh ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well shouldn’t it be 8?
---
helmfiles:
- "generic/*"
- path: "generic/*"
values:
- {{ .Values | toYaml | nindent 8 }}
with 8 it should be rendered to
helmfiles:
- "generic/*"
- path: "generic/*"
values:
- foo: bar
baz: 1
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
It looks like it should be 4
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ll make it 8 and see what happens
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
why 4? you pasted the helmfile.yaml with wrong indentation?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just going strictly by the output which was:
4: values:
5: -
6: values:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but I was looking at the wrong values:
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
those numbers from 4 to 6 are line numbers
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, I wasn’t looking at those
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I was looking at the indentation of the values
on line 6 instead of line 4
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
cool
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I think we got past that
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
nice
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
now we’re back on the environments.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the template
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
err: failed to read ../../common/environments.yaml: reading document at index 1: yaml: line 4: mapping values are not allowed in this context
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
looks like a syntax thing likely
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah, line 4 does have wrong indentation
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
templates:
versions: &versions
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
i wrote this but this should be
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I see it
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it’s 2+ and it needs to be 2-
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
templates:
versions: &versions
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
OK, so getting closer. If you are OK with helping me fix this one thing then I’ll stop bugging you for the rest of the day…lol (I need to go to bed) and then I’ll try and fix up the rest on my own and if I get stuck, I’ll let you know and hopefully you can help another time?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yeah sure! but expect i won’t be as responsive as today tomorrow. today was my day off.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
doh! maybe I’ll just stay up…lol
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well, let’s see
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
There’s something I need to do to fix the other helmfile.yaml files for each chart which rely on environments.yaml
in common
err: failed to read ../../common/environments.yaml: reading document at index 1: yaml: unmarshal errors:
line 4: field semver not found in type state.TemplateSpec
line 7: field ambassador not found in type state.TemplateSpec
line 10: field certmanager not found in type state.TemplateSpec
line 13: field blscauxclusterissuer not found in type state.TemplateSpec
line 16: field externaldns not found in type state.TemplateSpec
line 19: field nginxingress not found in type state.TemplateSpec
line 22: field postgres not found in type state.TemplateSpec
line 25: field oauth2proxy not found in type state.TemplateSpec
line 28: field dex not found in type state.TemplateSpec
line 31: field vaultoperator not found in type state.TemplateSpec
line 34: field vaultsecretswebhook not found in type state.TemplateSpec
line 38: field aws_nlb_with_tls_termination_at_lb not found in type state.TemplateSpec
line 39: field arm64_support not found in type state.TemplateSpec
line 40: field domain_name not found in type state.TemplateSpec
line 41: field cluster_id not found in type state.TemplateSpec
changing working directory back to "/project/helmfile-project/helmfile.d/generic/01a-network-and-proxies"
changing working directory back to "/project/helmfile-project/helmfile.d"
changing working directory back to "/project/helmfile-project/helmfile/envs/dev/atreus"
in ./helmfile.yaml: in .helmfiles[0]: in ../../../../helmfile.d/helmfile.yaml: in .helmfiles[0]: in generic/01a-network-and-proxies/helmfile.yaml: in .helmfiles[0]: in ambassador/helmfile.yaml: failed to read ../../common/environments.yaml: reading document at index 1: yaml: unmarshal errors:
line 4: field semver not found in type state.TemplateSpec
line 7: field ambassador not found in type state.TemplateSpec
line 10: field certmanager not found in type state.TemplateSpec
line 13: field blscauxclusterissuer not found in type state.TemplateSpec
line 16: field externaldns not found in type state.TemplateSpec
line 19: field nginxingress not found in type state.TemplateSpec
line 22: field postgres not found in type state.TemplateSpec
line 25: field oauth2proxy not found in type state.TemplateSpec
line 28: field dex not found in type state.TemplateSpec
line 31: field vaultoperator not found in type state.TemplateSpec
line 34: field vaultsecretswebhook not found in type state.TemplateSpec
line 38: field aws_nlb_with_tls_termination_at_lb not found in type state.TemplateSpec
line 39: field arm64_support not found in type state.TemplateSpec
line 40: field domain_name not found in type state.TemplateSpec
line 41: field cluster_id not found in type state.TemplateSpec
this looks like an indentation issue and I think I probably need to fix the reference to match what we did with the other helmfile.yaml files.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it will be helpful if you could push the latest snapshot of your whole setup before asking questions that would reduce forth-and-back
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems to
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sure! do you need that now or just in case I need more help tomorrow?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
btw, sincerely appreciate your assistance. Very kind!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
just update your git repo immediately before you add another question so that i can try to replicate your issue and think concretely
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
state.TemplateSpec
is the underlying go struct that maps to templates
in helmfile.yaml and in your case environments.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
cool! will do. Due to the nature of the company policies, I just need to sync between the public repo and my private repo here and then commit/push which will take a few mins.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah! ok, that’s good context.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah ok turns out we were only able to define some fields under templates.foo
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well then we can’t leverage templates
that way..
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
looks like I’ll need to add helmdefaults to the template
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh, we can’t?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
helmDefaults contains default values for releases[]
so it might be useful elsewhere, but i think it doesn’t work for this
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well trying to come up with a workaround..
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
k
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I guess I’m not understanding what’s wrong with the template method we’re working on right now.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the helmfile.yaml
files I updated a while ago were just the ones in the middle
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I didn’t update any of the chart helmfile.yaml files yet
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
how about this…
environments:
template:
values:
- versions: &versions
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
certmanager:
version: 1.0.4
namespace: certmanager
blscauxclusterissuer:
version: 0.1.0
namespace: certmanager
externaldns:
version: v20210203-v0.7.6-28-g44288212-arm64v8
namespace: externaldns
nginxingress:
version: 3.15.2
namespace: ingress-nginx
postgres:
version: x.x.x
namespace: grafana
oauth2proxy:
version: 3.2.5
namespace: auth-system
dex:
version: 2.15.2
namespace: dex
vaultoperator:
version: 1.8.1
namespace: vault
vaultsecretswebhook:
version: 1.8.2
namespace: secrets-webhook
values: *values
aws_nlb_with_tls_termination_at_lb: {{ .Values | get "aws_nlb_with_tls_termination_at_lb" false }}
arm64_support: {{ .Values | get "arm64_support" false }}
domain_name: {{ .Values | get "domain_name" (env "DOMAIN_NAME") }}
cluster_id: {{ .Values | get "cluster_id" (env "CLUSTER_ID") }}
---
environments:
default:
values:
- *versions
- *values
production:
values:
- *versions
- *values
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lemme give it a shot
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah probably this doesnt work due to yaml anchors not persisnt across ---
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
what if you removed ---
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
environments:
template:
values:
- versions: &versions
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
certmanager:
version: 1.0.4
namespace: certmanager
blscauxclusterissuer:
version: 0.1.0
namespace: certmanager
externaldns:
version: v20210203-v0.7.6-28-g44288212-arm64v8
namespace: externaldns
nginxingress:
version: 3.15.2
namespace: ingress-nginx
postgres:
version: x.x.x
namespace: grafana
oauth2proxy:
version: 3.2.5
namespace: auth-system
dex:
version: 2.15.2
namespace: dex
vaultoperator:
version: 1.8.1
namespace: vault
vaultsecretswebhook:
version: 1.8.2
namespace: secrets-webhook
values: *values
aws_nlb_with_tls_termination_at_lb: {{ .Values | get "aws_nlb_with_tls_termination_at_lb" false }}
arm64_support: {{ .Values | get "arm64_support" false }}
domain_name: {{ .Values | get "domain_name" (env "DOMAIN_NAME") }}
cluster_id: {{ .Values | get "cluster_id" (env "CLUSTER_ID") }}
environments:
default:
values:
- *versions
- *values
production:
values:
- *versions
- *values
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
removing ---
isn’t usually a good idea as this gudes you into the deep sea of helmfile “double-rendering” hack
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, it seems that one needs to understand when and when not to use ---
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, so quick question…
I’m trying to set up the ambassador/helmfile.yaml
to use the passed .Values
and I’m not 100% sure how to properly do that. The old helmfile.yaml
for ambassador was:
---
bases:
- ../../common/environments.yaml
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
---
releases:
- name: ambassador
namespace: {{ .Values.ambassador.namespace }}
createNamespace: true
labels:
app: ambassador
chart: datawire/ambassador
version: {{ .Values.ambassador.version }}
values:
- values.yaml.gotmpl
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the one I just tried, which failed was:
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
---
values:
- {{ .Values | toYaml | nindent 8 }}
releases:
- name: ambassador
namespace: {{ .Values.ambassador.namespace }}
createNamespace: true
labels:
app: ambassador
chart: datawire/ambassador
version: {{ .Values.ambassador.version }}
values:
- values.yaml.gotmpl
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
wrong indentation there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the last resort- try this if removing ---
didn’t work
environments:
{{ .Environment.Name }}:
values:
- versions:
semver: 0.0.1
name: somename
# Versions here reflect the chart version, NOT the app version.
ambassador:
version: 6.6.2
namespace: ambassador
certmanager:
version: 1.0.4
namespace: certmanager
blscauxclusterissuer:
version: 0.1.0
namespace: certmanager
externaldns:
version: v20210203-v0.7.6-28-g44288212-arm64v8
namespace: externaldns
nginxingress:
version: 3.15.2
namespace: ingress-nginx
postgres:
version: x.x.x
namespace: grafana
oauth2proxy:
version: 3.2.5
namespace: auth-system
dex:
version: 2.15.2
namespace: dex
vaultoperator:
version: 1.8.1
namespace: vault
vaultsecretswebhook:
version: 1.8.2
namespace: secrets-webhook
values:
aws_nlb_with_tls_termination_at_lb: {{ .Values | get "aws_nlb_with_tls_termination_at_lb" false }}
arm64_support: {{ .Values | get "arm64_support" false }}
domain_name: {{ .Values | get "domain_name" (env "DOMAIN_NAME") }}
cluster_id: {{ .Values | get "cluster_id" (env "CLUSTER_ID") }}
you may need to rename environments.yaml
to environments.yaml.gotmpl
. i forgot full details but try renaming the file if it failed to render go template at all
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh! yeah, that might be required
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
values:
- {{ .Values | toYaml | nindent 8 }}
seems like a invalid indentation
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
should be 4
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if you removed ` - ../../common/environments.yaml ` from the ambassador helmfile.yaml, it should end up like that
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
because you’ve tried todefine ambassador.namespace in the versions
, which was to be loaded via environments.yaml
you just removed
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but that should be passed in using the intermediate .Values
now, though shouldn’t it?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Intermediate .Values
doesn’t contain values defined in versions
neither, as you’ve omitted it from bases
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
hmm.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
values:
- {{ .Values | toYaml | nindent 8 }}
is noop.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you are basically assigning Values to Values
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah, yes. I was originally going to try just:
---
{{ .Values | toYaml }}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
in helmfiel.yaml?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
(that wasn’t the whole thing…just the values portion)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that would break helmfile.yaml, as it can’t contain arbitary key values like that
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I could put it under bases:
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you can only have artibrary key values under values
of some kind. like releases[].values
or environments[].values
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it’s not a free-form yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
aahhh. OK, that’s good to know.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so let me do this then: … (one min)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
nope. bases
has its own schema
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
#config.yaml
---
environments:
default:
values:
- {{ .Values | toYaml | nindent 8 }}
---
releases:
- name: ambassador
namespace: {{ .Values.ambassador.namespace }}
createNamespace: true
labels:
app: ambassador
chart: datawire/ambassador
version: {{ .Values.ambassador.version }}
values:
- values.yaml.gotmpl
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems ok, except that nindent should be 6
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
or I just need to push the indentation out 2 to match everything else.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
dang flexibleness of yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
maybe..?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i thought you usually align yaml dict key values at the level indicated by the end of the selection shown in the below picture
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
which is 6
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yaml allows either or
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it can be aligned or pushed out
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
wow really!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I tend to push it out because I’m old school
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yep
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the new school way seems to be aligned, though
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but make two files using both pragmas and yamllint them
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it will work on both
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
oh well but i still don’t get it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
lets say you had tis values
foo: bar
bar: baz
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
environments:
default:
values:
- {{ .Values | toYaml | nindent 8 }}
renders to
environments:
default:
values:
- foo: bar
bar: baz
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh, maybe I should qualify what I’m talking about…I’m talking only for lists.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
this does really work?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah gotcha
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
then you should still say nindent 6
there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
environments:
default:
values:
-
{{ .Values | toYaml | indent 6 }}
if it’s indent
rather than nindent
this should work
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
or even this
environments:
default:
values:
-
{{ .Values | toYaml | indent 8 }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
what’s the difference in go templating between nindent
and indent
btw? I haven’t looked up the docs on that yet.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
fixed wrong indentations in indent
examples
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep that’s very important
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that’s why nindent of 8 ends up with https://sweetops.slack.com/archives/CE5NGCB9Q/p1618909727197500?thread_ts=1618580632.114500&cid=CE5NGCB9Q here
environments:
default:
values:
- {{ .Values | toYaml | nindent 8 }}
renders to
environments:
default:
values:
- foo: bar
bar: baz
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
this is very common trick in writing not only helmfile templates but also helm templates so i’d highly recommend getting used to this
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the things so far
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
note that I renamed environments.yaml
to environments.yaml.gotmpl
to respect helmfile
to render go templatized file
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but I’m not sure that was enough…I feel like I need to tell helmfile to actually use the gotmpl file.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but where?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you need to add that back to bases
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i thought you just removed it from bases
earlier?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
which helmfile.yaml
file ? All of them?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I thought you said it needed to be removed.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I might have misunderstood you though
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well no
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
because we were trying to solve the directory path issue…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the directory path issue would have been resolved when we embedded versions.yaml and values.yaml.gotmpl into environments.yaml.gotmpl
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
neither environments.yaml
nor environments.yaml.gotmpl
is going to be included in bases
or loaded before rendering helmfile.yaml
, except you explicitly add it to bases
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you need to be explicit about what values to load, what bases to use, what values to be passed to sub-helmfile
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok. so that last thing is pretty good info. That resonates with me…and I’ll need to think about my project in those terms now methinks.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s actually something that should probably be added to the documentation like…very. clearly.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
let me make I am understanding what you’re saying, too…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
definitely. the point is that i know too much about helmfile already and can’t imagine what parts are missing to what levels of people
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
for a project, one must be explicit (for each helmfile.yaml) about what values to load, what bases to load and then when layering, what values to pass “down the chain”
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so if you could contribute doc addition/fix based on your experience, that would be awesome
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
absolutely!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and put it in terms of this project
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so let me see if I understand how we’ve done things so far in terms of that concept and this project
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I envisioned a project where I could deploy dex via helmfile from within its own directory and all it needs to know is where to find the bases, environments values (if any) and any additional values (for this project in this context, that would be passed in via env vars)…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
brb…2 mins
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i’ll be afk for dinner but keep posting
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
oh, and I think it worth a new slack thread now
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lol. OK
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
its getting really long and takes a bit of time to fully load, and im also afraid if every update to this thread is being notified to anyone commented on this thread only in very beginning
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@jedineeper is the concept I’m trying to accomplish making sense?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just want to make sure I’m not daft
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
cool, I created a new thread that we can move this to if you want.
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
This started with me misunderstanding the use of environments so some of it is beyond the scale of my understanding so I’m not a good judge :)
2021-04-17
2021-04-18
2021-04-19
2021-04-20
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu we can continue the thread here
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
here goes
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu I’ve pushed all my changes; and stuff is broke but it’s like almost 430 AM here and I need to get to bed.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
if you don’t mind though, give it a looksee. I’ll see if I can make heads or tails of it tomorrow
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
will try to find some time!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m not thinking straight though, anymore. So, again, really appreciate all your help.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
thank you very much! I’ll chat you up later today/tomorrow your time.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
g’night
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/d384e/d384ed2d598ea1fa4dc8f24771c1035d44c6c975" alt="Alex Genco avatar"
Hello! I’m new to helmfile and need some guidance on a use case. I’m adding a nested helmfile inside a monorepo-like helmfile repository. The parent repo so far doesn’t use environments since all services are global, but my child helmfile benefits greatly from them, because it defines production and staging namespaces and deployments. My helmfile looks basically like this:
environments:
staging:
values:
- staging.yaml
production:
values:
- production.yaml
releases:
- name: app
chart: foo/app
namespace: app-{{.Environment.Name}}
values:
- values.yaml.gotmpl
This works great as long as I specify -e staging
or -e production
during helmfile apply
. But since the parent repo has no concept of environments, it breaks the deploy process.
I guess my question is, what’s the best way to “inline” environments into the releases
list? i.e. I would like something like this:
releases:
- name: app-staging
chart: foo/app
namespace: app-staging
values:
- staging.yaml
- values.yaml.gotmpl
- name: app-production
chart: foo/app
namespace: app-production
values:
- production.yaml
- values.yaml.gotmpl
However, it’s attempting to “merge” the values files, rather than use the first to fill in the template of the second. Is there a better way to do this, rather than just duplicating the mostly-identical values files?
data:image/s3,"s3://crabby-images/19878/19878f14335ff8951cc92126f82d6805d5b7f629" alt="gonzalez.mariano.gabr avatar"
hey @Alex Genco have you tried using dependencies
? you can define a release with its dependencies so that the child chart will inherit values with <child_chart> prefix - see https://github.com/roboll/helmfile/issues/1762 for reference
Hi all. I am facing an issue with local dependencies declaration part of a release, as follows: releases: - name: foo_rel namespace: foo_ns chart: foo_example dependencies: - name: dep_chart reposi…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I guess my question is, what’s the best way to “inline” environments
im not sure if i understand fully, but it seems like you’ve already made it concise and DRY enough.
If i were you i won’t try to make it DRY further, thinking doing so would hurt readability
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if really want, you can still do this with standard go template techniques
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
like
{{ define "t" }}
- name: app-{{ .env }}
chart: foo/app
namespace: app-{{ .env }}
values:
- {{ .env }}.yaml
- values.yaml.gotmpl
{{ end }}
releases:
{{ template "t" (dist "env" "staging" ) }}
{{ template "t" (dist "env" "production" ) }}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i believe you’d better use a more serious configuration language like CUE if you need to dynamically generate helmfile.yamls at this level. FYI, CUE is https://cuelang.org/
Validate and define text-based and dynamic configuration
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
but i thought i’ve seen many people happy with https://sweetops.slack.com/archives/CE5NGCB9Q/p1618995133219700?thread_ts=1618934290.213300&cid=CE5NGCB9Q so i can imagine you’ll like it, too
like
{{ define "t" }}
- name: app-{{ .env }}
chart: foo/app
namespace: app-{{ .env }}
values:
- {{ .env }}.yaml
- values.yaml.gotmpl
{{ end }}
releases:
{{ template "t" (dist "env" "staging" ) }}
{{ template "t" (dist "env" "production" ) }}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
But since the parent repo has no concept of environments, it breaks the deploy process.
Well, i guess the reality is that the parent repo does have the concept of environments, but they are hidden. If the parent has no environnment, children shouldn’t have environments
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
If the parent envs are just hidden and you don’t want to write
environments:
staging: {}
production: {}
in parent, you may prefer
environments:
{{ .Environment.Name }}: {}
---
# releases, helmfiles, etc
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Hi, I’m doing hemlfile sync
to change from a internet-facing
alb to a internal
alb and I tried destroy
, sync
and diff
but even though there is changes the alb does not get get created, anyone had and issue like this before?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@jose.amengual Hey! It sounds like issues in the helm chart you’re using. Helmfile’s just calling helm uprade --install
or helm delete
or whatever according to the definitions in your helmfile.yaml so that kind of issues can be very likely to be caused by the chart, not helmfile
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
interesting ok, I will have a look
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I used a different namespace and everything works
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
if I destroy
, and delete other resources lingering and use the same namespace that did not work before it does not create the alb
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so there must be something still there
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
now I wonder how I can find it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
from the docs on NLBs…
Do not modify the service annotation service.beta.kubernetes.io/aws-load-balancer-type on an existing service object. If you need to modify the underlying AWS LoadBalancer type, for example from classic to NLB, delete the kubernetes service first and create again with the correct annotation. Failure to do so will result in leaked AWS load balancer resources.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
There are two issues i faced while trying to use single load balancer feature new ingress resource is failing to add ALB with new ingress group name (works only when the resource group name is chan…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that @Andriy Knysh (Cloud Posse) found is real…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
if you modify resources created by the controller int he console, you will have orphan resources
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
in my case the ingress what still there
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so I run kubectl patch ingress ingress-name -n namespace-name -p '{"metadata":{"finalizers":[]}}' --type=merge
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and then the ingress was gone and I was able to run helmfile sync
and helmfile destroy
and everything worked as expected
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@jose.amengual it seems like it would be a better use-case for terraform ¯_(ツ)_/¯ — Do you have some helmchart you’re using to deploy your ALB?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes we have some we use
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@Alex Genco I’d try to help you but I’m in the same boat as you man. Still learning.
2021-04-21
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
is there any way to ignore helm errors for a specific release and continue?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
generally no. but im curious why you want to do that?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
also, what’s the exact error you’re trying to ignore?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
so there is an issue I created a week ago https://github.com/roboll/helmfile/issues/1778
When using helmfile apply with repositories: - name: prometheus-community url: https://prometheus-community.github.io/helm-charts releases: - name: test namespace: test chart: prometheus-community/…
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
and I am trying to workaround it
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
we need to override some default rules from kube prometheus stack, my original idea was to use a patch, but since that didn’t work now I am trying another approach
unfortunately it involves a duplicate resource inside the kube prometheus release: I use additionalPrometheusRules with the name of already existing rule
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
so helm fails when it sees the duplicate, I was under impression that everything still works fine after that but now I see that this actually happens in the middle of deployment, so some resources are missing after it
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
so probably ignoring the error won’t be actually helpful in this case
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
but I have another question now:
if a release fails then further apply attempts do not show any errors but also do not deploy missing resources - is that expected behaviour?
(that’s what led me to believe that everything is find after the error)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
one possible workaround is to create a hook in which you run a script that performs a helm template
on the chart and then you kubectl apply -f -
on the template output patching whatever is necessary on the broken bits on a pipe in between template
and kubectl
— essentially you’d just fix the manifests as they’re being templatized. It’s ugly and a total hack and might be bug prone…but it’s an idea maybe?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
thank you for the idea, Jim
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Eugene Korekin I’ve tried to reproduce your issue but had no luck. please see https://github.com/roboll/helmfile/issues/1778#issuecomment-824441138
When using helmfile apply with repositories: - name: prometheus-community url: https://prometheus-community.github.io/helm-charts releases: - name: test namespace: test chart: prometheus-community/…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
perhaps your issue had already been fixed later prs?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if you still have some issue, sharing the reproduction steps on a brand-new cluster would be helpful
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
@mumoshu the behaviour is definitely different with the latest version from master
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
When using helmfile apply with repositories: - name: prometheus-community url: https://prometheus-community.github.io/helm-charts releases: - name: test namespace: test chart: prometheus-community/…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i have managed to let helmfile fail with another error and it does seem like a bug
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the one i saw seems happen when you do have strategicmergepatches/jsonpatches + CRDs
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
right, but there is another issue
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
whats it?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
looks like there is some regression in the master comparing to the stable version
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
just a moment
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
so here is a simple helmfile
repositories:
- name: prometheus-community
url: <https://prometheus-community.github.io/helm-charts>
releases:
- name: test
namespace: test
chart: prometheus-community/kube-prometheus-stack
version: ~14.4.0
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
it works without any issue with the stable version please note that it works without disableValidation
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
and I ensured that the crds weren’t present before the installation (deploying a new clean cluster right now to be 100% sure)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
whoa really? i cant imagine how it can work without disableValidation now…
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
ok, that’s probably because I used --skip-diff-on-install
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah that makes sense
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it’s me who added helm diff --disable-validation
to avoid helm-diff failing when trying to diff custom resources for CRD that isn’t installed yet
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so yeah, --skip-diff-on-install
would make disableValidation
unnecessary. got it
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
btw, would it be good idea if helmfile from master will print something different as its version number, not the same string as the stable version?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
I am having issues trying to understand which version I use sometimes, cause --version
gives the same results for stable and master
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah sounds good. i thought the version number if set via TAG = $(shell git describe --tags --abbrev=0 HEAD)
in Makefile
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i was innocently believing that it would return any tag only on tagged commit but apparently not
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Ah okay i see
git-describe
The command finds the most recent tag that is reachable from a commit
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
looks like there is some regression in the master comparing to the stable version
ok, please disregard this
I just checked and they both work in the same way
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
great. thanks for testing!
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
so, do you need any other information from my side regarding this issue with jsonpatches and crds?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i believe you’ve provided me enough! thx. i’m now wondering how i could fix that
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems helmfile needs to extract CRDs from the patched YAML and put it under crds
dir in the temp chart…. shouldn’t there be any easier way than this
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
thank you very much
if it won’t be possible to fix, I think specifying that json and strategic merge patches don’t work with CRDs in documentation would be very useful
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i cant help wishing there was helm template --crds-only
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep true
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Matt Farina is a friend of mine. I can suggest that to him.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i would generally prefer putting crds in a separate chart and then you’re fine
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I used to work with him.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
cool!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Eugene Korekin another potential solution would be to enhance helmfile to accept skipCRDs: true
in helmfile.yaml.
Then you could have a separate release for CRDs only and another for kube-promehtheus-stack with skipCRDs: true
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
where in the skipCRDs
ed kube-promehtue-stack release, you can freely use patching
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
that separate release for CRDs, should it be created manually in that case?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
or is there some automatic way to just install CRDs (from kube-prometheus-stack for example)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you can defintiely create em manually, but can i ask you why?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
nope. so i mean you need to copy CRDs from the kube-prometheus-stack into your own local chart
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
ok, I see yes, that’s what I meant by doing that manually
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well just a sec
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
as opposed to providing some option to helmfile so only CRDs will be installed from a chart
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
can’t we use our go-getter integration to grab and install CRDs only, assuming kube-promehtue-stack is hosted on GitHub?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
that would be great
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
but couldn’t CRDs also use some templating like other helm chart resources?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
maybe no..? i have never heard of CRDs being dynamically generated in practice
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
I mean, it might be easy to get and install them or manually copy them from a chart if they are just static, but what if not?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
maybe. it all depends on what we want? if you’d like to avoid manual steps using go-getter integration to install CRDs only in a separate chart can be a good workaround
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
otherwise just create a local chart containing CRDs only manually, or even install CRDs before running helmfile make sense
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
sure, it will work if they are always static and having this integration would be helpful because they could change with a new version of a chart
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
right
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
I was just thinking about an edge case when they are dynamic, in that case the go-getter integration will break, right?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
but I have little understanding about how they are usually used in charts, so probably I am just missing something, nevermind
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I was just thinking about an edge case when they are dynamic, in that case the go-getter integration will break, right?
absolutely.
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
just an additional thought: if the root of this issue is in chartify behaviour, maybe the proper way to fix it would be on the chartify level?
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
I don’t know what chartify is though and how it relates to helm
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
but if it generates helm charts then this:
the temporary chart generated by chartify is not a correct helm3 chart
looks like a bug in it, right?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes. i consider it’s a bug in chartify and i’m trying to fix it there. the implementation is going to be tedious so that’s why i wished if there was helm template --only-crds
earlier in this thread
data:image/s3,"s3://crabby-images/818c2/818c26ace9fe7883a0c16f574524e993af04e816" alt="Eugene Korekin avatar"
ah, got it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
this seems to be working https://github.com/variantdev/chartify/commit/55b23f9e9d43ae1105a536a659fa35f004806b2a
i will try integrate this into helmfile tomorrow or so
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
This version fixes that charitfy not to fail when you used the combination of (1)helm 3 and (2)strategicMergePatches/jsonPatches/transformers etc that triggers chartify on (3)a chart that contains …
2021-04-22
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Victor Farcic spread the word about Helmfile on his channel: https://www.youtube.com/watch?v=qIJt8Iq8Zb0
2021-04-23
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
guys, is there any replacement for deprecated inclubator/raw chart ?
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
A few people have forked it and published their version on artifacthub, but none of them have gained community adoption. Personally I still feel fine using the deprecated chart from helm/charts/incubator since it is stable and doesn’t need many updates. It set out to accomplish this one thing people need, attained it, and now just sits, not really needing much maintenance
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
That deprecation warning in latest version of chart breaks yaml..
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Of course, I can use older one, but that breaks other things for me
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Seems that bitnami has one..
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Even cloudposse, monochart..
data:image/s3,"s3://crabby-images/fc608/fc608efc80bfc1d9a9b7f26deb85a38b5c1cbf67" alt="Leia Renée avatar"
Hi guys , Do you have a sample repository which installs kubernetes cluster auto scaler that works with TF 15.0 properly I was using cookie labs which broken after upgrade. Thanks Leia https://www.linkedin.com/in/leia-renee/
2021-04-24
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu I hope that helps more (the example I just gave in the issue. I’m heading to bed now…
Note that the example manifests from upstream (vault) show no single tics around the property. I added those for testing. With or without, it seems to be valid yaml. You can apply it successfully with kubectl
but helmfile
doesn’t process it right. Thanks for your help.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I can’t even imagine how i could use that yaml in combination with vault-operator! You’d need to provide a step-by-step guide and your original goal.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
You can apply it successfully with kubectl but helmfile doesn’t process it right. Thanks for your help.
Why are you comparsing kubectl and helmfile? Should you compare helm and helmfile…?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Is vaultconfig
you’ve shown in https://github.com/roboll/helmfile/issues/1798#issuecomment-826049375 is considered a valid k8s manifest yaml that can be kubectl-apply
ed?
From vault chart documentation to show official documentation about the format of the policy: https://github.com/banzaicloud/bank-vaults/blob/master/charts/vault/values.yaml (note that the link abo…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
But it doesn’t look so. I’m super confused
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Im not even sure why you’re correlating
56: externalConfig:
57: policies:
58: - name: allow_secrets
59: rules: 'path "secret/*" { capabilities = ["create", "read", "update", "delete", "list"] }'. <<== fails
60: auth:
61: - type: kubernetes
...
with
err: failed to read helmfile.yaml: reading document at index 1: yaml: line 68: did not find expected ',' or ']'
in ./helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: line 68: did not find expected ',' or ']'
the line number doesn’t match
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
vaultconfig: |-
kind: Vault
name: vault
namespace: vault
What’s the extra indentation before name
and namespace
here…?
Shouldn’t that be
vaultconfig: |-
kind: Vault
name: vault
namespace: vault
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I’m not sure how this vaultconfig
is supposed to be used. It isn’t look like a valid values accepted by vault-operator chart nor a valid K8s manfist that can be applied.
Are you using it to dynamically render helmfile.yaml?
But then it should be a yaml dict, not a yaml string.
if it’s supposed to be a yaml dict, you should’nt have ` | - ` in: |
vaultconfig: |-
kind: Vault
name: vault
namespace: vault
spec:
it should be
vaultconfig:
kind: Vault
name: vault
namespace: vault
spec:
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
You say your example is enough for reproduction. This is so tough…. I tried my best but have no idea what you’re trying to achieve, what you tried, why/how this is supposed to work, etc.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Strange indentation here
externalConfig:
policies:
- name: allow_secrets
rules: 'path "secret/*" { capabilities = ["create", "read", "update", "delete", "list"] }'
auth:
- type: kubernetes
roles:
- name: default
bound_service_account_names:
auth:
- type: kubernetes
roles:
should be
auth:
- type: kubernetes
roles:
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
same here
auth:
- type: kubernetes
roles:
- name: default
bound_service_account_names:
secrets:
- path: secret
secrets: should be indented one more
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
From vault chart documentation to show official documentation about the format of the policy: https://github.com/banzaicloud/bank-vaults/blob/master/charts/vault/values.yaml (note that the link abo…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seriously, you shouldn’t embed a complete YAML in a YAML string. That can obfuscate all kinds of yaml errors, I believe.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
OK. Gotta a lot here I have to address.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
- I somehow managed to miss
metadata
in my example in the issue. Fixed. - The CR I had in my repository was wrong, as well. It was missing the
apiVersion
: Fixed.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
The way this installation works is that the vault-operator is installed via helm and then this manifest, which is the vault configuration (kind: Vault
) is installed. The vault operator picks up the requested config and asserts it for vault.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
an example of how this works can be seen in this comment
Is your feature request related to a problem? Please describe. current use-case involves attempting to install kube-prometheus-stack/alertmanager, which contains three directives we want to store/r…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ve never heard of a problem embedding yaml in yaml given placing the yaml in an appropriate property using an appropriate yaml modifier. It is common practice in every place I’ve worked so I’ve never heard of anyone say not to do it and I’ve been doing this a loooong time. So, meh, not sure. Agree to disagree on that? =]
There are a couple of important points to make about the indentation issues you pointed out:
- it was from copy and paste so something between the copy, paste, and gh markdown might have borked the actual indentation.
- The pasted yaml is coming from sops decrypted data and sops re-arranges yaml from the original input to its own from the time a document is first encrypted. For instance, notice the
- key:
entries? I never write yaml where there is more than one space after the dash. SOPS does that.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ll go through and fix yaml indentations issues I find. I was in a hurry to get to bed. It was late and I was keeping my wife up be staying up.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
one final thing. The yaml config I gave you was not a values.yaml file. I guess I should have just called it a CR manifest. I probably worded that in a weird way where confusion ensued. I provided the values.yaml example in the beginning to point out the property pointed out was sanely written as that was the only example, at the time, that I had and it was from a prominent example; upstream. So, that’s all I was using the values file for. We don’t use that values manifest. Moreover, given the sensitivity of what’s in this repo, I can’t just give you a copy. I have to scrub everything. So, the best example I can give you now on how to reproduce this is that GH comment #1270 I gave you, which is another issue I’m working with upstream on to figure out a problem we’re seeing with vault secrets webhook.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I just tried using your fixed manifest from GH and it still fails for me so there might be a different issue. Lemme show you my helmfile.yaml
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
- ../../common/versions.yaml
{{- if not .Values }}
- ../../common/values.yaml.gotmpl
{{- end }}
---
environments:
default:
secrets:
- secrets.yaml
---
releases:
- name: vault-operator
namespace: {{ .Values.vaultoperator.namespace }}
createNamespace: true
labels:
app: vault-operator
chart: {{ .Values.vaultoperator.repo }}
version: {{ .Values.vaultoperator.version }}
hooks:
- events: ["postinstall"]
command: "bash"
args: ["-c","echo \"{{ .Values.vaultconfig }}\"", "kubectl -n {{ .Values.vaultoperator.namespace }} -f -"]
showlogs: true
values:
- values.yaml
The CR I’m trying to load is the secrets.yaml
Now, I’m trying to test the postinstall hook, but yaml isn’t even getting that far yet.
When I run helmfile template
I get the following:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and that’s using the fixed manifest you provided with the fixed missing entries I found.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah geez. I just thought of something. I don’t need to load this into a value at all. Sigh. I’ll just use the postinstall hook and call sops to decrypt pipe it into kubectl directly. It would have been nice just use the internal secrets processing but this way I can get around this bug.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
args: ["-c","echo \"{{ .Values.vaultconfig }}\"", "kubectl -n {{ .Values.vaultoperator.namespace }} -f -"]
This looks bad. You have "
in vaultconfig
so the second arg in args
is delimited there, which seems unexpected to you
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, I just refactored all of that. I wasn’t sure it would work or not
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you seem to be trying to read stdin here "kubectl -n {{ .Values.vaultoperator.namespace }} -f -" but you you’re missing | | between echo and kubectl |
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah…I don’t expect a pipe would work in the args
property anyway, which I was using bash-fu to get around, which didn’t work…plus I neglected to even use apply
to kubectl
, but like I said, I was trying to get to a point to test that.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but I’ve switched gears and not even going to use helmfile/helm/secrets et al
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
since I’m applying a cr, which I should have thought about this before. I’m just gonna use sops in a hook and decrypt into kubectl. I’m writing a small wrapper shell function to handle all the things
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
fyi a common way to install arbitrary k8s resources using helmfile is to use incubator/raw
chart
releases:
- name: resources
namespace: vault
createNamespace: true
chart: incubator/raw
values:
- resources:
- {{ .Values.vaultconfig | nindent4 }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
btw, I’m not sure how well you know bash stuffs…but the method of input I was going for was:
$ < file command
which a stdin redirect into command
…it’s gooder
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
to let it not fail on first install you’d definitely want to have disableValidation
too
releases:
- name: resources
namespace: vault
createNamespace: true
chart: incubator/raw
values:
- resources:
- {{ .Values.vaultconfig | nindent4 }}
disableValidation: true
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ve never heard of the raw chart. Very interesting
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
to make it installed only after youve installed vault-operator, add needs
releases:
- name: resources
namespace: vault
createNamespace: true
chart: incubator/raw
values:
- resources:
- {{ .Values.vaultconfig | nindent4 }}
needs:
- {{ .Values.vaultoperator.namespace }}/vault-operator
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’ll give that a try but first I’d need helmfile to successfully read the cr
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep. but that should be easy as long as you won’t break yaml somehow.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so but that’s the problem I was trying to surface. I wasn’t breaking any yaml though things didn’t get into the issue very nicely…so that caused problems for you. I was in a rush so I fixed all that this morning.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so did you try to address my comment and you still get some error?
args: ["-c","echo \"{{ .Values.vaultconfig }}\"", "kubectl -n {{ .Values.vaultoperator.namespace }} -f -"]
This looks bad. You have "
in vaultconfig
so the second arg in args
is delimited there, which seems unexpected to you
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well, I already refactored all of it, but lemme run a test real fast with your suggestion.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
gimme like 5 mins.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I’ve never heard of a problem embedding yaml in yaml given placing the yaml in an appropriate property using an appropriate yaml modifier. It is common practice in every place I’ve worked so I’ve never heard of anyone say not to do it and I’ve been doing this a loooong time. So, meh, not sure. Agree to disagree on that? =]
well sorry but what i wanted to say is that you should really avoid using go template and yaml in such way if it makes debugging harder for you.
it did made debugging harder for you, right?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
cant’ you just create a your own local helm chart dedicated to installing Vault
resources, so that you don’t even need templating the whole helmfile.yaml?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so, there are lotsa ways to skin this cat in my estimation…I’m trying to employ the easiest method I find that works.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it looked like the easiest, but apparently not, right? :)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
apparently
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I’ve never heard of a problem embedding yaml in yaml given placing the yaml in an appropriate property using an appropriate yaml modifier
maybe you were thinking about embedding yaml in yaml without go templating here, right?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so this is the test I just ran
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
- ../../common/versions.yaml
{{- if not .Values }}
- ../../common/values.yaml.gotmpl
{{- end }}
---
environments:
default:
secrets:
- secrets.yaml
---
releases:
- name: vault-operator
namespace: {{ .Values.vaultoperator.namespace }}
createNamespace: true
labels:
app: vault-operator
chart: {{ .Values.vaultoperator.repo }}
version: {{ .Values.vaultoperator.version }}
hooks:
- events: ["postinstall"]
command: "echo "
#args: ["-c","cat<<E {{ .Values.vaultconfig }}\nE", "|", "kubectl -n {{ .Values.vaultoperator.namespace }} apply -f -"]
args: "{{ .Values.vaultconfig }}"
showlogs: true
values:
- values.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
is there anything wrong with that so far?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
whats in values.yaml now?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes, you need to remove
#args: ["-c","cat<<E {{ .Values.vaultconfig }}\nE", "|", "kubectl -n {{ .Values.vaultoperator.namespace }} apply -f -"]
` at all
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
values.yaml or secrets.yaml (secrets.yaml is what’s getting read)
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, I’ll remove it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
#args: ["-c","cat<<E {{ .Values.vaultconfig }}\nE", "|", "kubectl -n {{ .Values.vaultoperator.namespace }} apply -f -"]
is clearly breaking your yaml because #
will be applied to the first line of your loooong yaml string vaultconfig
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh yeah…actually that was another thing I noticed about helmfile…comments are not always handled very nicely…but I might just misunderstand something there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you’re somehow treating go template expression can be commeted out with yaml’s #
but that’s not the case
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you need to be extra sure that you’re writing a go template to generate a valid yaml yourself.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
#
is a yaml directive so it won’t disable go template in the line
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
hmm. that’s actually new to me. Interesting. I’ll have to look that up.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
OK…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
here’s the test I just ran…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
in an encrypted secrets.yaml:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and here’s the helmfile.yaml
again:
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
- ../../common/versions.yaml
{{- if not .Values }}
- ../../common/values.yaml.gotmpl
{{- end }}
---
environments:
default:
secrets:
- secrets.yaml
---
releases:
- name: vault-operator
namespace: {{ .Values.vaultoperator.namespace }}
createNamespace: true
labels:
app: vault-operator
chart: {{ .Values.vaultoperator.repo }}
version: {{ .Values.vaultoperator.version }}
hooks:
- events: ["postinstall"]
command: "echo "
args: "{{ .Values.vaultconfig }}"
showlogs: true
values:
- values.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
when I run this, I get the following error:
$ helmfile --debug template
...
...
...
err: failed to read helmfile.yaml: reading document at index 1: yaml: line 11: did not find expected key
in ./helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: line 11: did not find expected key
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
what’s in the line 11 of your rendered helmfile.yaml shown in the debug log?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
could you provide me the whole log?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so what I’m seeing is happening is that the echo command is reading the yaml file and then it seems to be trying to assert it to release in the yaml:
this is confusing:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
man…!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hooks:
- events: ["postinstall"]
command: "echo "
args: "{{ .Values.vaultconfig }}"
this seems wrong
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, lemme get you the whole log…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
shouldn’t it be
hooks:
- events: ["postinstall"]
command: "echo "
args:
-|
{{ .Values.vaultconfig | nindent 8 }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
uhhh
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
see this!!!
11: args: "apiVersion: "someapi/endpoint"
12: manifest:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
should it be? That goes against any convention of using a shell command with args I’ve ever seen…so this would be great to have documented.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m just trying to get the example simply echo out the variable
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes. but you’re breaking yaml there
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sorry. this is starting to get frustrating. I think there’s a fundamental lack of understanding of how this hook is supposed to work.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
It seems like using a hook with a bash command that “args” is not actually supposed to cause yaml interpretation
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m not trying to assert yaml in this example
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hmmm… well yes, you seem to have a fundamental misunderstanding
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I just want to see the yaml output…and I’m doing that with a bash eecho
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
why is helmfile trying to assert that?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
"{{ .Values.vaultconfig }}"
doesn’t automatically escape the yaml embedded in valutconfig
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
does that clarify it a bit?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
not really. unfortunately.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
maybe I can explain how this looks to the enduser
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hm. then try
args: {{ .Values.vaultconfig | toYaml }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
hooks:
- events: ["postinstall"]
command: "echo "
args: "{{ .Values.vaultconfig }}"
showlogs: true
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
this tells me the following
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
there’s a hook event to be executed during postinstall
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well not really
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
use the echo
command and use the args {{ .Values.vaultconfig }}
and echo that out…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
do nothing else
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hooks:
- events: ["postinstall"]
command: "echo "
args: "{{ .Values.vaultconfig }}"
showlogs: true
tells you that you render this snippet of go template to generate a yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and only after that helmfile’s able to read the hooks definition
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
Helmfile triggers various events
while it is running. Once events
are triggered, associated hooks
are executed, by running the command
with args
. The standard output of the command
will be displayed if showlogs
is set and it’s value is true
.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the documentation says nothing about rendering
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yeah true. but that only happens all the go template expressions are rendered
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it specifically says executed
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yeah true. this go template thing applies to helmfile, not only to hooks
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that’s why the doc doesn’t bother repeating all over the places….
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if you don’t use go template at all, you can treat it helmfie.yaml as a plain yaml file so there’s no issue at all
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
and i suppose that might be the fundamental misunderstanding you had
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
the use of command:
to me indicates some kind of terminal based command can be executed
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and args:
indicates arguments which will get passed to command
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
if helmfile reads yaml before rendering go template, even this doesn’t work
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
- ../../common/versions.yaml
{{- if not .Values }}
- ../../common/values.yaml.gotmpl
{{- end }}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
because
{{- if not .Values }}
- ../../common/values.yaml.gotmpl
{{- end }}
is clearly invalid as yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yes
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the use of command: to me indicates some kind of terminal based command can be execute
and args: indicates arguments which will get passed to command
correct
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so all your understanding on hooks, command, args seem correct
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
but you’re breaking yaml before they are defined at all.. which is what helmfile’s complaining about.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
well, ok, but lemme finish my thought real fast
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so, it seems that helmfile
should only be looking for an exit code from the command…what ever else the command performs should be interpreted by helmfile. I would think.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
should reading {{ .Values.vaultconfig }}
just be the entire yaml output from the file? In it’s own right, it’s valid yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but helmfile seems to be concatenating it to everything else
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep, because that’s how go template works…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
maybe
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well internally helmfile does differentiate each arg in args
.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so
but helmfile seems to be concatenating it to everything else
if you’re referring to how go template is working here, you’re correct
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i can imagine a valid feature request here would be
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
somehow enhancing args
so that you can source a file content into one arg
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
or a helmfile value content into one arg
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
like
hooks:
- events: ["postinstall"]
command: "echo "
args:
- fromHelmfileValue: vaultconig
showlogs: true
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so you’re failing here…
11: args: " <<<< ==== everything in the template here should be passed to bash and ignored by helmfile
12: apiVersion: "someapi/endpoint"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
The yaml in the file, which is read into .Values.vaultconfig
by itself is valid yaml.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yeah but you arent embedding it correctly
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m not trying to embed it!!! lol. That’s the thing. I don’t understand why helmfile is trying to embed that to args
in releases
— that’s not making sense to me.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
why not use
args :
- |
{{ .Values.vaultconfig | nident SOME_NUMBER
as i’ve suggested
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so perhaps you can help me understand that one part.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m trying to find that magic number…just a sec
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I don’t understand why helmfile is trying to embed that to args in releases
Becase you’re telling helmfile to do so here…
args: “{{ .Values.vaultconfig }}”
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
this is with nindent 10
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but I’m not!! I’m telling helmfile to pass the transliterated template to echo
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
or at least that’s what I’m trying to do
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I don’t want helmfile to attach anything in args
to the releases
object.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
are you really using:
args:
- |
{{ .Values.vaultconfig | nindent SOME_NUMBER }}
in the above run?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I just want it to pass the “stuff” in args
to echo
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
nope.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
then it won’t work
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
1 ---
2 bases:
3 - ../../common/repos.yaml
4 - ../../common/helmdefaults.yaml
5 - ../../common/versions.yaml
6 {{- if not .Values }}
7 - ../../common/values.yaml.gotmpl
8 {{- end }}
9
10 ---
11 environments:
12 default:
13 | secrets:
14 | | - secrets.yaml
15
16 ---
17 releases:
18 - name: vault-operator
19 | namespace: {{ .Values.vaultoperator.namespace }}
20 | createNamespace: true
21 | labels:
22 | | app: vault-operator
23 | chart: {{ .Values.vaultoperator.repo }}
24 | version: {{ .Values.vaultoperator.version }}
25 | hooks:
26 | | - events: ["postinstall"]
27 | | | command: "echo "
28 | | | args: "{{ .Values.vaultconfig | nindent 10 }}"
29 | | | showlogs: true
30 | values:
31 | | - values.yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, so maybe let me see if understand how helmfile
works then in this regard…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hooks:
- events: ["postinstall"]
command: "echo "
args:
- |
{{ .Values.vaultconfig | nindent SOME_NUMBER }}
try this
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
hooks:
- events: ["postinstall"]
command: "echo "
args:
- {{ .Values.vaultconfig | nindent 12 }}
showlogs: true
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yeah it should end up like that..
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
why you used
args:
-
instead of what i suggested above:
args:
- |
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
tried both.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
same error
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
9: - events: ["postinstall"]
10: command: "echo "
11: args:
12: -
13: apiVersion: "someapi/endpoint"
14: manifest:
15: kind: Vault
16: name: vault
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
err: failed to read helmfile.yaml: reading document at index 1: yaml: unmarshal errors:
line 14: cannot unmarshal !!map into string
in ./helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: unmarshal errors:
line 14: cannot unmarshal !!map into string
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
although, indentation is off in second one. Lemme fix that
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
1: args:
12: -
13: apiVersion: "someapi/endpoint"
14: manifest:
15: kind: Vault
err: failed to read helmfile.yaml: reading document at index 1: yaml: unmarshal errors:
line 14: cannot unmarshal !!map into string
in ./helmfile.yaml: failed to read helmfile.yaml: reading document at index 1: yaml: unmarshal errors:
line 14: cannot unmarshal !!map into string
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
25 | hooks:
26 | | - events: ["postinstall"]
27 | | | command: "echo "
28 | | | args:
29 | | | - {{ .Values.vaultconfig | nindent 10 }}
30 | | | showlogs: true
31 | values:
32 | | - values.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
where”s the - |
now? mind sharing me the whole helmfile.yaml after you’ve wrote - |
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
---
bases:
- ../../common/repos.yaml
- ../../common/helmdefaults.yaml
- ../../common/versions.yaml
{{- if not .Values }}
- ../../common/values.yaml.gotmpl
{{- end }}
---
environments:
default:
secrets:
- secrets.yaml
---
releases:
- name: vault-operator
namespace: {{ .Values.vaultoperator.namespace }}
createNamespace: true
labels:
app: vault-operator
chart: {{ .Values.vaultoperator.repo }}
version: {{ .Values.vaultoperator.version }}
hooks:
- events: ["postinstall"]
command: "echo "
args:
- {{ .Values.vaultconfig | nindent 10 }}
showlogs: true
values:
- values.yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
wheres - |
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I used this for your recommendation: https://sweetops.slack.com/archives/CE5NGCB9Q/p1619300555282000?thread_ts=1619249294.249600&cid=CE5NGCB9Q
hooks:
- events: ["postinstall"]
command: "echo "
args:
- {{ .Values.vaultconfig | nindent SOME_NUMBER }}
try this
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
did I miss a |-
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
should that be after args:
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah no
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
well, do this
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
args:
- |
{{ .Values.vaultconfig | nindent SOME_NUMBER }}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
k, sec
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok. so no errors that time…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
checking through all the output.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
btw this might also work
args: ["{{`{{.Values.vaultconfig}}`}}"]
probably you’ve already read https://github.com/roboll/helmfile/#hooks but totally missed the existence of “go template comment” there?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, I was considering trying that next actually
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I haven’t read that actually
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
really don’t forget making it a go template comment if you try the above
{{`
`}}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ok
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I found an example helmfile.yaml that used that in a hook so I was going to try it
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
regardless of you use go template comment or not, embed yaml into args
at the helmfile.yaml level or before helmfile running the hook command, all i can say is
https://sweetops.slack.com/archives/CE5NGCB9Q/p1619299403271500?thread_ts=1619249294.249600&cid=CE5NGCB9Q
hooks:
- events: ["postinstall"]
command: "echo "
args: "{{ .Values.vaultconfig }}"
showlogs: true
tells you that you render this snippet of go template to generate a yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
helmfile firstly renders the whole helmfile.yaml content as a go template. helmfile reads the result as yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you can use go template comment like https://sweetops.slack.com/archives/CE5NGCB9Q/p1619301420288500?thread_ts=1619249294.249600&cid=CE5NGCB9Q so that you can “defer” the go template rendering.
BUT it doesn’t mean that helmfile stopped rendering the go template.
really don’t forget making it a go template comment if you try the above
{{`
`}}
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
OK, that’s good info there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
even if you had no go template expression in helmfile.yaml, helmfile tries to render it as a go template before parsing as yaml.
a valid yaml can easily become a valid go template too. so, as long as you don’t go template in helmfile.yaml at all, helmfile.yaml looks like a vanilla yaml
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
So, I’m running this with helmfile sync --args --dry-run
— will the hook work during a helm dry-run?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m not getting errors now but I’m also not seeing the echo of the stuff in the file.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
haven’t tried. helmfile --args
is not well supported
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
meh, ok. Lemme just sync and see what happens
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
nope. dang it.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
not even any logs
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
wait a sec
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
helmfile --args
is a historical artifact that only worked in the very beginning of the helmfile project. at that time helmfile sync
only ran a single helm command.
nowadays a helmfile run involves many helm commands so --args
doesn’t make sense. Which custom args should be passed to helm template
, helm template
, helm diff
, helm repo up
, helm dep build
, etc? Impossible to deduce
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh boy. That’s not very good because sometimes I want to see what helm debug looks like and what it would template out
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s a valid point though
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
seems like it should be a good idea to allow the user to pass dry-run to upgrade --install
though.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i agree. sounds like a good chance for you to write a feature request
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
lol. can do
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I’m confused here in what is happening in my testing here…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
no echo command from postinstall
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ah geez
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
oh well, you said postinstall?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah…don’t say it. I figured it out
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i remember someone has requested it before… found it. https://github.com/roboll/helmfile/issues/1291#issuecomment-638153828
I am just wondering exactly when presync and postsync hooks are run, specifically: Are they run if a release is being uninstalled? Are they run if a release is already uninstalled and installed: fa…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, a postinstall
for this use-case would be prime
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
ok, giving this a shot now…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
27 | | | command: "echo"
28 | | | args: ["{{ `{{ .Values.vaultconfig }}` }}","|","kubectl -n {{ `{{ .Vault.vaultoperator.namespace }}` }} apply -f -"]
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
created an issue for that at #1805. please feel free to add your voice w/ expected use-case there https://github.com/roboll/helmfile/issues/1805
Just wanted to have a dedicated issue for this. Would anyone use it if Helmfile added a new postinstall hook? It has been originally proposed by @cdunford in #1291. Althought I thought it was great…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Does adding space between {{
and the backtick like that work?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yup. that’s how we do gotemplate comments for everything (it’s our convention)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I thought go template comment had to start with
{{
`
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ok then
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
just gotta fixup a couple things here and then this might work….
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
hm, i think i’ve found another potential issue in your config
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
oh, cool. I’m listening
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
maybe yo’ve already noticed, but you should use bash
or alike instead of directly calling echo
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
yeah, just fixed that
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
nice
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
command: "bash"
args: ["-c", "echo", "{{ `{{ .Values.vaultconfig }}` }}","|","kubectl -n {{ `{{ .Values.vaultoperator.namespace }}` }} apply -f -"]
but I think the |
is illegal unless helmfile
knows how to handle that. In my experience, most things don’t properly interpret the pipe in this context
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yes, i can see your point
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
output from sync
Listing releases matching ^vault-operator$
vault-operator vault 10 2021-04-24 15:21:08.377398548 -0700 PDT deployed vault-operator-1.8.1 1.8.0
helmfile.yaml: basePath=.
hook[postsync] logs |
hook[postsync] logs |
UPDATED RELEASES:
NAME CHART VERSION
vault-operator banzaicloud-stable/vault-operator 1.8.1
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
but
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
at 15:21:36 ❯ kg vault vault
Error from server (NotFound): vaults.vault.banzaicloud.com "vault" not found
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so no errors, but no resource either
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it’s quick and dirty, but I can echo that out to a tmpfile and have kubectl read the tmp file, then shred it.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s kind of what I was working on before actually
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
actually…lemme try one more thing
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
sounds good
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i have also managed to do it with bash here doc
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
values:
- somePlainYaml: |
apiVersion: v1
kind: ConfigMap
metadata:
name: frompostsync
---
releases:
- name: myapp
chart: incubator/raw
values:
- resources:
- metadata:
name: myapp
kind: ConfigMap
apiVersion: v1
hooks:
- events: ["postsync"]
command: "bash"
args:
- -c
- |
cat <<EOS | kubectl apply -f -
{{ .Values.somePlainYaml | nindent 6 }}
EOS
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s what I was kinda working on…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sheez…forgot to remove the pipe
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
nice
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
it works
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
- events: ["postsync"]
command: "bash"
args:
- "-c"
- |-
< <(echo -e "{{ `{{ .Values.vaultconfig | nindent 6 }}` }}") \
kubectl --validate=false -n {{ `{{ .Values.vaultoperator.namespace }}` }} apply -f -
showlogs: true
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
awesome!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
man
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i’d still recommend the use of bash here doc there
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
can you articulate why?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so that you can avoid a potential issue of echo part breaking due to some character in vaultconfig
breaking the bash string
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
that’s pretty good reason
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it won’t break always. but i would still think it as a good practice to use bash here doc there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that way all you need to care is that you don’t have any bash here doc delimiter in vaultconfig
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
there might be other ways. its just that bash here doc is the best way i can think of
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
in many ways, fd vivication is better but echo can be squirrely
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I wouldn’t use echo
in fact, but the newlines are important and it seemed that newlines got swallowed up in a straight grok in my quick testing.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
er
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
something like that. I’m trying to go by memory…I’m also switching contexts a lot here so trying to keep everything straight is iffy
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
hey curious…what time is it there for you?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I think you’re in Japan right? Or is that a poor assumption?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
2021-04-25
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I’ve curated a list of important feature requests and planned changes https://github.com/roboll/helmfile/issues/1806 Please feel free to review and add your voices if you find anything interesting to you
This is going to be pinned to the header of our GitHub issues list so that everyone can be aware of and redirected to important planned features for discussion :) Allow opting in for inheriting all…
data:image/s3,"s3://crabby-images/6011a/6011a623bc49207a322b7b17a894fa24a1aa02c6" alt="fiesta_parrot"
2021-04-27
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
hi. is this a bug?
if I run helmfile lint
against helmfile.yaml that contains
helmfiles:
- environments/test1/helmfile.yaml
- environments/test2/helmfile3.yaml
it fails with Error: repo not found
it’s referring to a release located in helmfile3.yaml. if I remove the first line (environments/test1/helmfile.yaml) it works fine. btw, I am using helmBinary option to specify helm version in each of those helmfiles
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
if I run helmfile -f environments/test2/helmfile3.yaml repos
it works. shouldn’t it automatically fetch charts?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@es Does it work when you run helmfile -f environments/test1/helmfile.yaml repos
, too?
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
The repos in that file automatically fetch when I apply so I haven’t tested. I’m on latest helmfile version btw
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Are you using any of strategicMergePatches/forceNamespace/jsonPatches/dependencies/transformers
in your helmfile.yaml
then?
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
No
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I’m not aware of any relevant bug that is fixed in the unreleased version of helmfile, at least
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
https://pastebin.com/Gt4EU67h - thanks in advance and please let me know if you need more information.
Pastebin.com is the number one paste tool since 2002. Pastebin is a website where you can store text online for a set period of time.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@es Thanks! Would you mind sharing me the exact version numbers of /usr/local/bin/helm
and /usr/local/bin/helm3
?
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
it’s there, you probably missed it. sec
# helmfile version;helm version;helm3 version
helmfile version v0.138.7
Client: &version.Version{SemVer:"v2.15.1", GitCommit:"cf1de4f8ba70eded310918a8af3a96bfe8e7683b", GitTreeState:"clean"}
Server: &version.Version{SemVer:"v2.15.1", GitCommit:"cf1de4f8ba70eded310918a8af3a96bfe8e7683b", GitTreeState:"clean"}
version.BuildInfo{Version:"v3.2.0", GitCommit:"e11b7ce3b12db2941e90399e874513fbd24bcb71", GitTreeState:"clean", GoVersion:"go1.13.10"}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Ah thanks. Let me check..
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Whoa, this helm2 is super outdated :slightly_smiling_face: I cant even run helm init --client-only
…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
touch ~/.helm/repository/repositories.yaml
did the job…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
so i was able to reproduce it with only
helmfiles:
- helmfile.jenkins1.yaml
- helmfile.jenkins2.yaml
helmfile.jenkins1.yaml
repositories:
- name: jenkins
url: "<https://charts.jenkins.io>"
releases:
- name: jenkins11
chart: jenkins/jenkins
version: "2.5.0"
helmfile.jenkins2.yaml
repositories:
- name: jenkins
url: "<https://charts.jenkins.io>"
helmBinary: helm2151
releases:
- name: jenkins21
chart: jenkins/jenkins
version: "3.3.9"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
this might be due to unnoticed race between helm2 and helm3 fetch
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
yeah - a similar configuration worked before adding helmBinary
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
after the failure it doesn’t even show up in helm2 repo list
so it maybe be race between helm repo add/up
of helm v2 and v3
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Almost certainly this is due to a helmfile bug. We usually skipp helm repo add
calls on already added repo. But we don’t differentiate calls between helm v2 and v3 there
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
https://github.com/roboll/helmfile/blob/ae942c5288895c84c79171e5446773e4cb41c4ce/pkg/app/context.go#L17-L25 https://github.com/roboll/helmfile/blob/ae942c5288895c84c79171e5446773e4cb41c4ce/pkg/state/state.go#L383
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/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that results in helm repo add jenkins ...
for helm 3 skips the subsequent helm repo add jenkins ...
for helm 2
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
yeah, I see. I just renamed the jenkins repo in helmfile3.yaml to something else and it worked fine
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Awesome! That’s a nice workaround
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
thanks for helping
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@es Would you mind creating a bug report in helmfile issues? I have a working local branch for fix
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@es Thanks for the writeup! Created the PR https://github.com/roboll/helmfile/pull/1816
Trying to helm repo add the same Helm chart repository to Helm V2 and V3 in a single Helmfile run had been resulting in an incomplete result, only the latter helm repo add being skipped. This fixes…
data:image/s3,"s3://crabby-images/caaab/caaab5b1f583a6b12cc20fecf22c60a7bf1bc674" alt="es avatar"
thank you @mumoshu
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Anyway, it would be great if you could provide provide us a more complete example for reproduction. At this point it’s too hard to say if it’s either a bug or not
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu I think I have a fundamental misunderstanding of how to use selectors for sub-helmfiles. You already have a basic skeleton of my repo/condition although I’ve made many changes to it so I’m gonna have to articulate my ask.
I’m using a layered approach to my helmfile project as you know. If you look in the generic
directory there is a 01a-…
and 01b…
directory for a tier of tools in each directory so I want to create a selector that would cause helmfile to 1) run everything in the respective 01a-…
and 01b-…
directories and 2) I want the flexibility to be able to just run one helmfile within a subdirectory of say, 01b-…
(essentially just installing a single chart). It seems to me that the documentation says that the selectors are defined in the helmfiles
directive of the parent directories to those sub-directories.
given: <project root>/helmfile.d/generic/01a-tier1
and <project root>/helmfile.d/generic/01b-tier2
if I want to be in helmfile.d
to run helmfile and I want to install just charts in 01b-tier2
then the helmfile.yaml
in helmfile.d
would have to define the selectors and point to the helmfile.yaml
in generic
defining the selectors with a path:
pointing to helmfile.yaml
in 01b-tier2
and so forth, correct?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
My helmfile.yaml
in helmfile.d
looks like:
# helmfile.yaml in helmfile.d
---
helmfiles:
- "generic/*"
- path: "generic/common/*"
My helmfile.yaml
in generic
is:
# helmfile.yaml in generic
---
helmfiles:
- "*/*.yaml"
- path: "common/*"
- path: "01a-network-and-proxies/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=network-and-proxies"
- path: "01b-secrets-management/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=secrets-managment"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
and finally, my helmfile.yaml
in 01b-…
for instance is:
# helmfile.yaml in security-management
---
helmfiles:
- "*/helmfile.yaml"
- path: "../common/*"
- path: "certmanager/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=secrets-managment"
- "app=certmanager"
- path: "vault-operator/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=secrets-managment"
- "app=vault-operator"
- path: "vault-secrets-webhook/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=secrets-managment"
- "app=vault-secrets-webhook"
- path: "dex/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=secrets-managment"
- "app=dex"
- path: "oauth2-proxy/helmfile.yaml"
values:
- {{ .Values | toYaml | nindent 8 }}
selectors:
- "tier=secrets-managment"
- "app=oauth2-proxy"
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I’m inclined to think that that is incorrect, though, because when I run sync --selectors tier=secrets-managment,app=dex
(or delete
) for instance, it runs everything:
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Why are you giving selectors:
for every sub-helmfile? What if you just omitted that and let it install all when helmfile sync
and let it install only part of releases with helmfile -l foo=bar sync
?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I guess because when I tested that, it didn’t work as I’d hoped…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
maybe I did something wrong.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I was just looking at https://github.com/roboll/helmfile/blob/master/examples/README.md and I saw that helmfile is able to use the release labels…
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
so I’ll check that out again and see if I can find out why that doesn’t work.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
nevertheless, I would like to be able to assign each full directory to a tier
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
sorry for the slow response. I was at the store.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
very cool. That seems to be working. Not sure what I was doing wrong before…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
noice!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I have to go to the store again to get something for my wife but if you can answer this while I’m gone… I thought I read in the docs once that there was a way to set a dependency up (like terraforms depends on) but of course, differently implemented. Did I misread that? For instance, our implementation of dex requires a running vault. I’m sure there are ways to set up the environment that such a thing could be jiggered but is there a native way for helmfile to do this type of functionality?
I’ll be back in about an hour
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
also, quick question about a thought on a feature request which may already exist. It would be super awesome if I could run an argument that would just show me the charts which would be affected by an operation on requested selector(s).
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Perhaps that might be something like a “dry-run” feature?
what Add option to process helmfile.yaml, but not execute helm why This would be helmfile for development use-case We're working on a master helmfile, kind of like a "distribution" of…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Or if you’re willing to just review which releases are eing selected by a specific selector, i think helmfile -l foo=bar list
works, as unlike helm list
, helmfile list
is able to list not-yet-installed releases
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Have you tried helmfile --interactive apply
?
It stops after printing the list of releases to be deleted and updated, and prompt you for confirmation (y/n).
What if helmfile apply --dry-run
worked exactly like that and automatically exist without prompting?
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
list works great!
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I haven’t tried –interactive yet. I’ll give it a go…
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
as for --dry-run
, I am not sure (yet) of how helm
asserts –dry-run. I would suppose that it does an actual dry-run against the cluster (like kubectl apply --dry-run=(client|server)
does (depending)). I would have to research how kubectl
asserts dry-runs first and how that correlates to how helm
asserts dry runs before intelligently answering the last question. Basically, when I do tell something to do dry-run, I’m assuming I’m performing several actions which will test the actual application state I’m requesting all the way to the end without actually committing anything to k8s.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
bbiab
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
cool. nm. don’t have to go now.
2021-04-28
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
I thought I read in the docs once that there was a way to set a dependency up (like terraforms depends on) but of course, differently implemented. Did I misread that?
For instance, our implementation of dex requires a running vault. I’m sure there are ways to set up the environment that such a thing could be jiggered but is there a native way for helmfile to do this type of functionality?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
needs
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/affc0/affc080883fc23037123859d7e1fb8db04d2673d" alt="Jim Conner avatar"
@mumoshu if you’re available: how on earth would one define globally used values for all releases in an environment. This has been my absolute biggest blocker. Even better is that the global scoped values.yaml could be also templatized. I cannot figure out how to achieve this goal. Nothing I’ve tried works.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
something like this?
values:
- someGobalValue: foo
---
values:
- {{ .Values | toYaml | nindent 2 }}
- anotherGlobalValue: {{ .Values.someGlobalValue }}bar
---
releases:
- name foo
chart: somechart
values:
- some: {{ .Values.someGlobalValue }}
another: {{ .Values.anotherGlobalValue }}
- name bar
chart: somechart
values:
- some: {{ .Values.someGlobalValue }}
another: {{ .Values.anotherGlobalValue }}
data:image/s3,"s3://crabby-images/72274/7227482e022bbf2e4339da3767f115c9e8a6f02c" alt="Vladimir Avdoshka avatar"
yes this is PR to add this in the doc https://github.com/roboll/helmfile/pull/1808
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"