I am aware of following thread and supposedly an answer to it. Except an answer is not an answer in generic sense. It tells what the problem was in one particular case, but not in general.
My question is: is there a way to debug ordering cycles in a generic way? E.g.: is there a command which will describe the cycle and what links one unit to another?
For example, I have following in journalctl -b (please disregard date, my system has no RTC to sync time with):
Jan 01 00:00:07 host0 systemd[1]: Found ordering cycle on sysinit.target/start Jan 01 00:00:07 host0 systemd[1]: Found dependency on local-fs.target/start Jan 01 00:00:07 host0 systemd[1]: Found dependency on cvol.service/start Jan 01 00:00:07 host0 systemd[1]: Found dependency on basic.target/start Jan 01 00:00:07 host0 systemd[1]: Found dependency on sockets.target/start Jan 01 00:00:07 host0 systemd[1]: Found dependency on dbus.socket/start Jan 01 00:00:07 host0 systemd[1]: Found dependency on sysinit.target/start Jan 01 00:00:07 host0 systemd[1]: Breaking ordering cycle by deleting job local-fs.target/start Jan 01 00:00:07 host0 systemd[1]: Job local-fs.target/start deleted to break ordering cycle starting with sysinit.target/start where cvol.service (the one that got introduced, and which breaks the cycle) is:
[Unit] Description=Mount Crypto Volume After=boot.mount Before=local-fs.target [Service] Type=oneshot RemainAfterExit=no ExecStart=/usr/bin/cryptsetup open /dev/*** cvol --key-file /boot/*** [Install] WantedBy=home.mount WantedBy=root.mount WantedBy=usr-local.mount According to journalctl, cvol.service wants basic.service, except that it doesn't, at least not obviously. Is there a command which would demonstrate where this link is derived from? And in general, is there a command, which would find the cycles and show where each link in the cycle originates?
