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

Ignition v3.x support #9157

Open
bengentil opened this issue Aug 9, 2023 · 25 comments
Open

Ignition v3.x support #9157

bengentil opened this issue Aug 9, 2023 · 25 comments
Labels
area/bootstrap Issues or PRs related to bootstrap providers area/provider/bootstrap-kubeadm Issues or PRs related to CAPBK kind/feature Categorizes issue or PR as related to a new feature. needs-triage Indicates an issue or PR lacks a `triage/foo` label and requires one. priority/important-soon Must be staffed and worked on either currently, or very soon, ideally in time for the next release.

Comments

@bengentil
Copy link
Contributor

What would you like to be added (User Story)?

As a user I would like to bootstrap Flatcar & FCOS with Ignition v3.x as Ignition v2.x doesn't work with FCOS and is only required for flatcar LTS release.

Detailed Description

The current implementation (Container Linux Config aka clc) is used when setting format to "ignition" in KubeadmConfigSpec.
To be able to support both v2.x & v3.x, a new field needs to be added to know which transpiler should be used:

  • clc for v2.x
  • butane for v3.x

Like in the current implementation, an additional butane config may be provided to extend/override the generated Ignition config.

Anything else you would like to add?

This issue follows this slack conversation: https://kubernetes.slack.com/archives/C8TSNPY4T/p1688643597808979

Label(s) to be applied

/kind feature
/area bootstrap
/area provider/bootstrap-kubeadm

@k8s-ci-robot k8s-ci-robot added kind/feature Categorizes issue or PR as related to a new feature. area/bootstrap Issues or PRs related to bootstrap providers area/provider/bootstrap-kubeadm Issues or PRs related to CAPBK needs-triage Indicates an issue or PR lacks a `triage/foo` label and requires one. labels Aug 9, 2023
@k8s-ci-robot
Copy link
Contributor

This issue is currently awaiting triage.

If CAPI contributors determines this is a relevant issue, they will accept it by applying the triage/accepted label and provide further guidance.

The triage/accepted label can be added by org members by writing /triage accepted in a comment.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

bengentil added a commit to bengentil/cluster-api that referenced this issue Aug 9, 2023
bengentil added a commit to bengentil/cluster-api that referenced this issue Aug 9, 2023
bengentil added a commit to bengentil/cluster-api that referenced this issue Aug 9, 2023
bengentil added a commit to bengentil/cluster-api that referenced this issue Aug 9, 2023
bengentil added a commit to bengentil/cluster-api that referenced this issue Aug 10, 2023
bengentil added a commit to bengentil/cluster-api that referenced this issue Aug 10, 2023
@vincepri
Copy link
Member

vincepri commented Sep 1, 2023

/priority important-soon

@k8s-ci-robot k8s-ci-robot added the priority/important-soon Must be staffed and worked on either currently, or very soon, ideally in time for the next release. label Sep 1, 2023
@JoelSpeed
Copy link
Contributor

I've been looking into this a little and concluded that resolving this should be relatively straight forward, at least, on the providers side.

Looking at AWS as an example. The only thing it does for ignition is to upload the existing ignition data to s3 and then create a stub ignition which points to the s3 bucket.

There are minor differences between v2 and v3, but, it's not hard to create a switch and support this by importing both the v2 and v3 types.

For kubeadm this may be a little bit more involved.

Does anyone know about the flatcar ignition fork vs the coreos ignition? I was looking at both today and as far as I can tell they are API compatible, but the coreos fork seems to be more active at the moment?

@bengentil
Copy link
Contributor Author

The PR addressing this issue is currently waiting on progress with #5294

see #9158 (comment) for more details

@johananl
Copy link
Member

johananl commented Sep 6, 2023

Does anyone know about the flatcar ignition fork vs the coreos ignition? I was looking at both today and as far as I can tell they are API compatible, but the coreos fork seems to be more active at the moment?

I think @pothos might know the answer.

@pothos
Copy link

pothos commented Sep 6, 2023

The forked repo is only used by Flatcar LTS. Flatcar Stable uses the CoreOS upstream repo (with some downstream patches to also support Ignition spec v2).

@JoelSpeed
Copy link
Contributor

Thanks @pothos, based on that, I think we should make sure we move back to the upstream coreos repo to import the types rather than using the forks, thanks for the context

@johananl
Copy link
Member

johananl commented Sep 6, 2023

We should consider this ☝️ in the context of #5294.

@k8s-triage-robot
Copy link

The Kubernetes project currently lacks enough contributors to adequately respond to all issues.

This bot triages un-triaged issues according to the following rules:

  • After 90d of inactivity, lifecycle/stale is applied
  • After 30d of inactivity since lifecycle/stale was applied, lifecycle/rotten is applied
  • After 30d of inactivity since lifecycle/rotten was applied, the issue is closed

You can:

  • Mark this issue as fresh with /remove-lifecycle stale
  • Close this issue with /close
  • Offer to help out with Issue Triage

Please send feedback to sig-contributor-experience at kubernetes/community.

/lifecycle stale

@k8s-ci-robot k8s-ci-robot added the lifecycle/stale Denotes an issue or PR has remained open with no activity and has become stale. label Jan 27, 2024
@johananl
Copy link
Member

/remove-lifecycle stale

@k8s-ci-robot k8s-ci-robot removed the lifecycle/stale Denotes an issue or PR has remained open with no activity and has become stale. label Jan 29, 2024
@k8s-triage-robot
Copy link

The Kubernetes project currently lacks enough contributors to adequately respond to all issues.

This bot triages un-triaged issues according to the following rules:

  • After 90d of inactivity, lifecycle/stale is applied
  • After 30d of inactivity since lifecycle/stale was applied, lifecycle/rotten is applied
  • After 30d of inactivity since lifecycle/rotten was applied, the issue is closed

You can:

  • Mark this issue as fresh with /remove-lifecycle stale
  • Close this issue with /close
  • Offer to help out with Issue Triage

Please send feedback to sig-contributor-experience at kubernetes/community.

/lifecycle stale

@k8s-ci-robot k8s-ci-robot added the lifecycle/stale Denotes an issue or PR has remained open with no activity and has become stale. label Apr 28, 2024
@johananl
Copy link
Member

johananl commented May 2, 2024

/remove-lifecycle stale

@k8s-ci-robot k8s-ci-robot removed the lifecycle/stale Denotes an issue or PR has remained open with no activity and has become stale. label May 2, 2024
@FR-Solution
Copy link

waite this feature)

@fabriziopandini
Copy link
Member

FYI
We currently don't have any maintainer for the ingnition code in the project 😓
Also, when we introduced ignition there was a general commitment to pay down the tech debt introduced by this choice before making further improvements in this area, but also for this effort there are no volunteers showing up (and it is a few years now)

Not really sure about what will be the next steps here (even if we keep the issue around)

@JoelSpeed
Copy link
Contributor

Just a note, I think since I last commented here we added ignition 3.x support to CAPA. We are not users of the KubeADM provider but may be able to help with implementation guidance if one of the existing users wants to work on it.

@bengentil
Copy link
Contributor Author

bengentil commented Aug 2, 2024

but also for this effort there are no volunteers showing up (and it is a few years now)

I submitted a PR addressing this feature but was advised to stop working on it as it would add additional dependencies and a larger rewrite was ongoing in this issue: #5294

#9158 (comment)

@Karthik-K-N
Copy link
Contributor

Hi, Was there any further discussion about taking this forward in slack or CAPI meeting? interested in getting this feature added to CAPI.

@defo89
Copy link

defo89 commented Sep 9, 2024

Hi, since the roadmap and timeline of #5294 is not clear, would the community consider revisiting merging #9158?

Being stuck with Ignition v2 for another year or two means:

  • not being able to use any modern OS with CAPBK unless an OS provides in-place v2 to v3 conversion (like Flatcar does)
  • not possible to use kernel arguments as of 3.3.0 (and other v3 features, too)
  • using legacy Ignition v2 that is deprecated long time ago

FWIW CAPBK should switch to Ignition v3 by default and base any other redesign work on it.

@fabriziopandini
Copy link
Member

FWIW CAPBK should switch to Ignition v3 by default and base any other redesign work on it.

In the past a similar decision in this area did not lead to the expected results (see #9157 (comment))

Considering this, and the current bandwidth of the folks actively maintaining the project, I'm personally -1 to continue down the current path just because there are not enough people investing on this feature and in paying down the technical debt related to it.

@mcbenjemaa
Copy link
Member

@fabriziopandini
can we announce this during the CAPI meeting, and we can probably gather some people interested in this topic, and we can start a WG for maintaining ignition?
I'm open and interested in maintaining it potentially along with other folks.

@t-lo
Copy link
Contributor

t-lo commented Oct 24, 2024

@fabriziopandini Flatcar would be interested in picking up maintenance and also investigate Ignition v3 support. However, a past requirement for introducing new features like v3 support was to re-write the whole bootstrap provider for clearer separation (see #5294) . That's too much for us considering it touches quite a few non-ignition related parts of the code base. If that's not a blocker anymore we'd be happy to look into supporting the Ignition feature.

@bengentil
Copy link
Contributor Author

If #5294 is no more a blocker, I'd be happy to help resuming the work in the PR #9158 or in a new PR

@fabriziopandini
Copy link
Member

Unfortunately, we are in this uncomfortable spot because we did not invested at the beginning, and I really want to get out from this situation. But adding on top of what we have today IMO is not a viable path.

I think we should get back to the original need: "I want to reuse some code from CABPK & KCP" and find better ways to address this, and most important quoting our manifest, "without increasing operational and conceptual complexity for Cluster API’s users." .

@t-lo
Copy link
Contributor

t-lo commented Oct 28, 2024

Unfortunately, we are in this uncomfortable spot because we did not invested at the beginning, and I really want to get out from this situation. But adding on top of what we have today IMO is not a viable path.

I share your concerns - but we don't actually want to add on top. We just want to keep ignition support up to date. Deprecated bits (like v2 support) would be removed. This is much more maintenance work than it is adding a feature.

@fabriziopandini
Copy link
Member

fabriziopandini commented Oct 28, 2024

When we introduced ignition there was a general commitment to pay down the tech debt introduced by this choice before making further improvements in this area, but also for this effort there are no volunteers showing up (and it is a few years now)

If no one is willing to pay down the tech debt, I'm -1 to keep going with what we have now.

I understand this might seem too much for PoV of the occasional contributor, but from the PoV of core maintainers, the amount of feature not properly taken care of is getting too much, and WRT to ignition there was prior discussions and decisions we should respect.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/bootstrap Issues or PRs related to bootstrap providers area/provider/bootstrap-kubeadm Issues or PRs related to CAPBK kind/feature Categorizes issue or PR as related to a new feature. needs-triage Indicates an issue or PR lacks a `triage/foo` label and requires one. priority/important-soon Must be staffed and worked on either currently, or very soon, ideally in time for the next release.
Projects
None yet
Development

Successfully merging a pull request may close this issue.