Skip to content
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

gracefull upgrades through terraform #140

Open
camaeel opened this issue Dec 24, 2023 · 7 comments
Open

gracefull upgrades through terraform #140

camaeel opened this issue Dec 24, 2023 · 7 comments

Comments

@camaeel
Copy link

camaeel commented Dec 24, 2023

Currently there is no option to trigger talos upgrade through terraform provider.
If I aplly new kubernetes version through talos resources all nodes get patched simultaneously.
It would be great to have resources to upgrade both talos itself and kubernetes in a gracefull way one by one node (like talosctl upgrade and taloscyl upgrade-k8s does).

Another option could be, to have builtin upgrade controller in talos controllers.

@M4t7e
Copy link

M4t7e commented Jun 19, 2024

IMHO, this is by far one of the most important functionalities missing in the Talos Terraform provider. To manage a Talos K8s cluster using only Terraform, we need a declarative and idempotent way to specify a target version. The lifecycle of a cluster should be considered more thoroughly. The Talos and Kubernetes versions also have be compatible with the additional components that may be needed, such as external CCM, CNI, CSI, etc. Talos introduces imperative change management here, which is undesirable in a Terraform environment. Therefore, I don't see any feasible way to conduct proper lifecycle management with this module.

@hegerdes
Copy link

As a workaround you can specify the parallelism Terrafrom Docs arg and setting it to 1 default is 10. So terraform will only do one resource at the time. When you pair this with the terraform time resource you can archive wait till the node is done.

Not pretty but bast we can do right now besides from gracefully replacing nodes

@perfectra1n
Copy link

Yeah, without a way to run talosctl upgrade when changing Talos versions or extensions via this provider is rough - it makes all the work done on this provider for naught. It is possible to first create the cluster using this provider, but being unable to upgrade the cluster through this provider is a huge bummer.

@nwmcsween
Copy link

nwmcsween commented Oct 23, 2024

This could be done with different "vm instance/server/etc" blocks, the initial block would create and destroy on any update and the second block would depend on data http to connect before creating/destroying. This is only for upgrading Talos and not k8s.

@divStar
Copy link

divStar commented Dec 26, 2024

I actually am interested in this, too. I suppose one could use local-exec, but it becomes very ugly very quickly.
There is also some idea I saw in https://blog.stonegarden.dev/articles/2024/08/talos-proxmox-tofu/, but to be perfectly honest I don't understand how it works.

And since I am on my homelab server with somewhat-limited resources, I wouldn't mind some downtime while upgrading, but I'd need it to e.g. destroy the current nodes and create new ones, mount the disk device blocks and boot everything - just like it currently does, but with VMs with newer versions of Talos.

Isn't it enough to just destroy and re-create the nodes with newer versions? Or should we prefer to "upgrade" running nodes?

@amaol-vestas
Copy link

amaol-vestas commented Jan 9, 2025

We need this feature in talos terraform provider, or the alternative is just a nasty bad code practice and very unstable kubernetes and talos upgrades, please @smira take this need into account, thanks

@ionfury
Copy link

ionfury commented Jan 20, 2025

I have the same issue. I implemented a nasty workaround with local-exec and a script.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants