-
Notifications
You must be signed in to change notification settings - Fork 158
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
40ignition-ostree: add service for deleting /etc enablements #363
Conversation
A lot of backstory on this, but essentially right now, we always bake a run of `systemctl preset-all` into the OSTree because upgrading hosts rely on these links for service enablement. In hindsight, we should've just stuck with pure systemd preset only as canonicaly from the get go, though it's a bit difficult now to transition from one to the other without breaking things. (Though I'll note not impossible, since we do have update barriers which could allow us to e.g. run a script to restore lost symlinks). For now though, let's at least fix the ability to disable services, which is a pretty big gap in our Ignition configuration story right now. Related: systemd/systemd#15205 Related: coreos#77 Closes: coreos/fedora-coreos-tracker#392
This is a short-term solution to coreos/fedora-coreos-tracker#392 while we figure out what the long-term strategy should be (discussions ongoing in systemd/systemd#15205). (To re-iterate, as mentioned in systemd/systemd#15205 (comment), yes, this is really awkward to basically undo what the OSTree commit is baking in.) |
This might actually not be as hard as I initially imagined. I didn't want to write systemd services for this that would muck around with analyzing a previous deployment's
Still a sensitive operation of course, given that failure potentially means a broken boot. Though it'd be a nice legacy cleanup. |
Thoughts on just merging this until systemd/systemd#15205 is decided (and possibly backported to Fedora/RHEL8)? |
To be honest I am scared of this 😄 Not to mention that the systemd PR seemed to come to a conclusion and looks likely to merge. (Once it does, we can just e.g. detect the systemd version in postprocess and not do the "copy units to /etc" right?) Plus we have a workaround for the zincati thing today (it's not a difficult workaround, but it's also admittedly not an obvious workaround - people are going to keep hitting that issue, but hopefully web search takes them to it quickly) |
Yeah I'm a bit wary. Since we have an easy workaround and hopefully some momentum upstream maybe let's just see if we can get that in sooner than later. Obviously if upstream lingers we can revisit. |
Sure, we can wait some more. I think there was a misconception on my part on how bad this actually is. |
Looks like upstream is lingering. And the service disablement issue continues to be UX wart. So I think we should consider doing something here. I actually don't think this PR is that scary. The main thing to note is that it's purely a first boot thing which means (1) lots of CI coverage, and (2) it cannot affect upgrading nodes. |
Actually, I think another approach here is to tweak Ignition so that |
While I agree that this PR is closer to what we actually want in the end, doing the above seems to be safer as a first step. |
This is coreos/ignition#588. |
Closing as per coreos/fedora-coreos-tracker#392 (comment) |
A lot of backstory on this, but essentially right now, we always bake a
run of
systemctl preset-all
into the OSTree because upgrading hostsrely on these links for service enablement.
In hindsight, we should've just stuck with pure systemd preset only as
canonicaly from the get go, though it's a bit difficult now to
transition from one to the other without breaking things. (Though I'll
note not impossible, since we do have update barriers which could allow
us to e.g. run a script to restore lost symlinks).
For now though, let's at least fix the ability to disable services,
which is a pretty big gap in our Ignition configuration story right now.
Related: systemd/systemd#15205
Related: #77
Closes: coreos/fedora-coreos-tracker#392