fully support package installation in systemd
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
cloud-init |
Fix Released
|
Critical
|
Unassigned | ||
cloud-init (Ubuntu) |
Fix Released
|
Critical
|
Unassigned | ||
Xenial |
Fix Released
|
High
|
Unassigned | ||
init-system-helpers (Ubuntu) |
Fix Released
|
High
|
Martin Pitt | ||
Xenial |
Fix Released
|
High
|
Unassigned |
Bug Description
in cloud-init users can install packages via cloud-config:
#cloud-config
packages: [apache2]
Due to some intricacies of systemd and service installation that doesn't work all that well.
We fixed the issue for simple services that do not have any dependencies on other services, or at least don't check those dependencies well under bug 1575572.
We'd like to have a way to fully support this in cloud-init.
Related bugs:
* bug 1575572: apache2 fails to start if installed via cloud config (on Xenial)
* bug 1611973: postgresql@9.5-main service not started if postgres installed via cloud-init
* bug 1621336: snapd.boot-
* bug 1620780: dev-sda2.device job running and times out
* bug 1623570: Azure: cannot start walinux agent (Transaction order is cyclic.)
* bug 1623868: cloud-final.service does not run due to dependency cycle
* bug 1627436: [gce] Startup scripts do not run on 1604 images
* bug 1624596: [azure] ephemeral-
SRU INFORMATION
===============
FIX for init-system-
REGRESSION POTENTIAL for init-system-
TEST CASE (for both packages):
Run
lxc launch ubuntu-daily:x --config=
This will install all three packages, but "systemctl status postgresql@
Now prepare a new image with the proposed cloud-init and init-system-
lxc launch ubuntu-daily:x xprep
lxc exec xprep bash
# enable -proposed and dist-upgrade, then poweroff
lxc publish xprep x-proposed
Now run the initial lxc launch again, but against that new x-proposed image instead of the standard daily:
lxc launch x-proposed --config=
You should now have "systemctl status postgresql@
Also test interactively installing a package that ships a service, like "apache2", and verify that it starts properly after installation.
Verify that journalctl shows no dependency cycles and that all cloud init services and the target are active:
$ systemctl list-units --no-legend --all 'cloud*'
cloud-config.
cloud-final.service loaded active exited Execute cloud user/final scripts
cloud-init-
cloud-init.service loaded active exited Initial cloud-init job (metadata service crawler)
cloud-config.target loaded active active Cloud-config availability
cloud-init.target loaded active active Cloud-init target
Related branches
- cloud-init Commiters: Pending requested
-
Diff: 50 lines (+9/-9)2 files modifiedconfig/cloud.cfg (+8/-8)
systemd/cloud-final.service (+1/-1)
Changed in cloud-init (Ubuntu): | |
status: | New → Confirmed |
importance: | Undecided → Medium |
Changed in cloud-init: | |
status: | New → Confirmed |
importance: | Undecided → Medium |
Changed in cloud-init (Ubuntu): | |
importance: | Medium → Critical |
Changed in cloud-init: | |
importance: | Medium → Critical |
tags: | added: sts |
description: | updated |
Changed in init-system-helpers (Ubuntu Xenial): | |
status: | New → Confirmed |
importance: | Undecided → High |
Changed in cloud-init (Ubuntu Xenial): | |
status: | New → Confirmed |
importance: | Undecided → High |
description: | updated |
Changed in cloud-init (Ubuntu Xenial): | |
status: | Confirmed → In Progress |
tags: |
added: verification-done removed: verification-needed |
description: | updated |
description: | updated |
description: | updated |
description: | updated |
Would it be possible to move package installation into a cloud-init- *.service that is "Type=idle", i. e. runs after booting is complete? This would avoid all these corner cases and breakage when trying to install/start things while booting is not complete yet.