Is there a way to see the execution tree of systemd?

What I mean under the question is: is there a way to dump the ordered list (like pstree does for processes) to see how systemd executed the supplied set of units, i.e. the tree after the dependencies were resolved and jobs were queued for the execution? I know that you can do it by analysing systemd state data, but is there a quick way to see such a tree? It would help a lot in failure investigation (e.g. if you see that the boot process was stuck on some unit you would be able to pinpoint the approximate location for your deeper investigation.


systemd-analyze is your friend. For example systemd-analyze critical-chain outputs blocking tree of daemons. Mine for example:

graphical.target @20.211s
└─multi-user.target @20.211s
  └─nginx.service @19.348s +862ms
    └─network.target @19.347s
      └─NetworkManager.service @10.315s +9.031s
        └─basic.target @10.312s
          └─timers.target @10.311s
            └─systemd-tmpfiles-clean.timer @10.311s
              └─sysinit.target @10.295s
                └─systemd-update-utmp.service @10.167s +127ms
                  └─systemd-tmpfiles-setup.service @10.124s +41ms
                    └─local-fs.target @10.097s
                      └─home-entd-Downloads.mount @10.093s +2ms
                        └─home.mount @9.326s +672ms
                          └─[email protected] @8.472s +696ms
                            └─dev-sda6.device @8.471s

NetworkManager in example basically holding entire bootup.

If you want to have more detailed view you can render entire execution chain in a svg file. systemd-analyze plot > something.svg outputs entire chain (120+ modules) as progress bars to high-res svg file which show states, that are blocked and another problems.

Finally you have systemd-analyze dot tool which outputs dot file which outputs entire hierarchy: systemd-analyze dot | dot -Tpng -o stuff.png with dot tool you can output it as ps and svg files too.

All of above tools are built-in in systemd-analyze tool which comes by default with systemd in archlinux at least. I think there is some 3rd party projects dealing with it too.


Not sure I properly understand the question, but there are tree visualizations available with the following commands :

sudo systemctl status

And also :

sudo systemctl list-dependencies 

Hope this helps :)

Also, it might be useful for other purposes to build a tree of the systemctl symlinks folders:

tree /etc/systemd/system

It was actually really useful to figure out old / buggy units that were slowing down my system startup, to disable them afterwards using the systemctl disable command.

EDIT

That said I really agree with the OP that this basic functionality should be given via command-line tools, and not a graphical tool... What if you cannot start X ? How you deal with your svg file then ?

Actually, there is a way. If you cannot use scp (ssh tool) to fetch your file on another computer, fbi might actually help you :)

sudo systemd-analyze plot > /home/user/startup.svg
fbi /home/user/startup.svg

Worked in my TTYs. Just navigate inside the picture with arrows. There are zooming options, to list do fbi -h.

Again I hope this helps. It is available in Archlinux and Ubuntu repos.

EDIT 2 :

fbi doesn't work over ssh. You can do X forwarding like this ssh -Y user@server, but you need a X server running on your remote server.

The best bet here is to use sshfs. It works GREAT in userspace, for instance with nautilus. There's a little configuration to do, see:

sudo vim /etc/fuse.conf #type a, uncomment the user_allow_other line and ESC :wq
sudo mkdir /mnt/yourmountingdir
sudo chown user:user /mnt/yourmountingdir
sshfs [email protected]:/home/user /mnt/yourmountingdir/ -o allow_other #Asks for host trusting and password
sudo fusermount -u /mnt/yourmountingdir/ #To disconnect and unmount

May still not fully answering your question but try with --fuzz option

systemd-analyze critical-chain --fuzz 1h

Note you can also specify units to see their critical-chain, so you're not limited to the multi-user.target

systemd-analyze critical-chain network.target local-fs.target

Hope this helps