-
Notifications
You must be signed in to change notification settings - Fork 169
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Problem with label tanka.dev/environment
hash
#824
Comments
I think the |
I'm keen to pick this up unless anyone has already started work on it as we're hitting this issue frequently. |
Hey @DeanBruntThirdfort , sorry I have been radio-silent here. I really wanted to work on this but life and work are not allowing me to. Feel free to work on it, and thank you for the offer! 🙏 |
This change adds support for overriding the environment label using fields on the environment as per grafana#824. To achieve this, the NameLabel() function that generates this needed to be lifted to the Environment struct (from Metadata) to ensure it can access the fields it needs. Additionally, its signature now returns an error as there are ways errors could occur during this generation now that should be surfaced neatly to the user.
Raised a PR here to add this support (pending maintainers being happy with the approach etc). |
I had same issue today. my workaround is to add an unique project folder like this
instead of this
seems to work. |
I also went down the same rabbit hole and discovered that the hash is computed from the environment name only, e.g. Some guidance should probably be added to the docs about either making the name of an environment unique, or maybe renaming the The approach in #975 would also work but I think it should be accompanied with better defaults, e.g. |
This change adds support for overriding the environment label using fields on the environment as per grafana#824. To achieve this, the NameLabel() function that generates this needed to be lifted to the Environment struct (from Metadata) to ensure it can access the fields it needs. Additionally, its signature now returns an error as there are ways errors could occur during this generation now that should be surfaced neatly to the user.
* feat: Add support for overriding environment label This change adds support for overriding the environment label using fields on the environment as per #824. To achieve this, the NameLabel() function that generates this needed to be lifted to the Environment struct (from Metadata) to ensure it can access the fields it needs. Additionally, its signature now returns an error as there are ways errors could occur during this generation now that should be surfaced neatly to the user. * Fix misspellings --------- Co-authored-by: Julien Duchesne <julien.duchesne@grafana.com>
Hi,
Playing around with some projects, I end up detecting that the label
tanka.dev/environment
(which is used to identify resources for an environment so they can be pruned if necessary) can have collisions in the case that you deploy different applications (in, for instance, different repositories) using the same "tanka environment". Example:The objective is to be able to deploy several applications into the same Kubernetes cluster, in a multi/microservice stack.
When running
tk apply
, both of those repositories produce the sametanka.dev/environment
label's value:cc3fe2eceb1805bc3b5cbeed010b0bd38c488b156d199a75
.How this value is produced: Looking at the code, I see this, which at first glance made me believe that it was using
.metadata.name
and.metadata.namespace
from the spec.json file. But a more in-depth look to the code shows that nothing from spec.json is used. Here's where those name and namespace values come from:So, the hash comes from a sha256 of
environments/myenv:environments/myenv/main.jsonnet
, which is exactly the same for both projects/repos.So, whenever repo1 is tk applied, it will delete repo2 resources and the other way around.
I understand the rationality behind how the hash is calculated (if same dir and file under
environments
, then same environment), but it is at least misleading (why the use of "metadata" to store this? Whyname
andnamespace
as property names for it?) and not flexible enough (according to my use case, which might not be common or part of the scope of Tanka).So this is what I would propose:
spec.json
file (under"spec"
). Example of the proposal:So this new property,
spec.tankaEnvLabelFromFields
can be a list of fields' paths from the samespec.json
file that the code can concatenate (in order) and produce the hash.I would like to know maintainers' opinion about it and if it is something you might consider if I work on a PR.
Cheers
The text was updated successfully, but these errors were encountered: