Skip to Content

How to Use systemctl list-dependencies in RHEL (Red Hat Enterprise Linux)

The systemctl list-dependencies command in Linux, using systemd, is a powerful tool for exploring the dependency relationships between various system units.

In systemd, units can have dependencies on each other — for example, one service might require another service to be running, or a target unit might depend on multiple services to function properly. This command allows you to view these dependencies in a tree-like structure, helping you understand how system services and resources are interconnected.

This guide will walk you through how to use the systemctl list-dependencies command in RHEL, including syntax, common options, and practical examples.

Syntax

systemctl list-dependencies [UNIT]
  • UNIT: The name of the systemd unit for which you want to list dependencies (e.g., a service, target, or socket). If no unit is specified, the command will show the dependencies of the default target (default.target).

Key Options:

  • --reverse: Shows units that depend on the specified unit (reverse dependencies).
  • --all: Includes inactive or not loaded units in the output.

Steps to Use systemctl list-dependencies

1. Listing Dependencies of a Service

To view the dependencies of a specific service, use the systemctl list-dependencies command followed by the name of the service unit. For example, if you want to list the dependencies of the Apache HTTP server (httpd), you would run:

Get Your Linux Course!

Join our Linux Course and discover the power of open-source technology. Enhance your skills and boost your career! Learn Linux today!
systemctl list-dependencies httpd.service

This will display a list of units that httpd.service depends on and other units that are required for httpd.service to function properly.

Example:

systemctl list-dependencies httpd.service

Output:

httpd.service
● ├─system.slice
● └─network.target
  • network.target: This indicates that httpd.service depends on the network being available.
  • system.slice: This is the default slice under which system services run.

2. Listing Dependencies of a Target (Runlevel)

Targets in systemd represent different system states or runlevels. To view the dependencies of a target, such as multi-user.target (which is a common target for multi-user, non-graphical systems), use:

systemctl list-dependencies multi-user.target

This shows all the services and other targets required for the multi-user run level to be fully functional.

Example:

systemctl list-dependencies multi-user.target

Output:

multi-user.target
● ├─graphical.target
● ├─basic.target
● ├─sockets.target
● ├─system.slice
● └─network.target
  • graphical.target: This is a higher-level target, typically for systems that need a graphical user interface (GUI).
  • basic.target: This target is used to initialize basic system components.
  • sockets.target: This target is used to start services waiting for socket connections.
  • network.target: This indicates that the network is up and ready.

3. Using --reverse to List Reverse Dependencies

Sometimes, you may want to find out which units depend on a specific unit. To do this, use the --reverse flag. For example, if you want to find out which services depend on the httpd.service, run:

systemctl list-dependencies --reverse httpd.service

This will show a list of units that depend on httpd.service to be running.

Example:

systemctl list-dependencies --reverse httpd.service

Output:

● ├─multi-user.target
● └─graphical.target

This tells you that httpd.service is required by both multi-user.target and graphical.target, meaning that the HTTP service is essential for those targets to function properly.

4. Including All Units (Active and Inactive)

By default, systemctl list-dependencies only shows units that are active or loaded. To see all units, including inactive ones, use the --all option. For example:

systemctl list-dependencies --all httpd.service

This will show you not only the active units but also any inactive or non-loaded units that might be part of the dependency tree.

Example:

systemctl list-dependencies --all httpd.service

Output:

httpd.service
● ├─system.slice
● ├─network.target
● ├─some-unloaded-unit.service

This output includes any units that are not loaded or inactive, which might be required under certain conditions.

5. Viewing the Dependencies of the Default Target

If you want to list the dependencies of the system’s default target (the one the system boots into), you can omit the unit name, and it will show the default target’s dependencies. For example:

systemctl list-dependencies

This will display the dependencies for the default target, which is typically either graphical.target or multi-user.target depending on your system setup.

Practical Use Cases

1. Troubleshooting Services

When a service isn’t starting or functioning as expected, knowing what it depends on can be helpful. For example, if httpd.service isn’t starting, you can use systemctl list-dependencies --reverse httpd.service to find out which other units are waiting for httpd to start. This can provide insight into what might be blocking the service from starting.

Example:

systemctl list-dependencies --reverse httpd.service

This will tell you which services or targets depend on httpd.service to be active.

2. Exploring System States

When managing RHEL systems, you might want to know which services will be started when a particular target is reached. For instance, if you are exploring the multi-user.target, use systemctl list-dependencies multi-user.target to see which services and targets are involved in the multi-user state.

Example:

systemctl list-dependencies multi-user.target

3. Verifying Services Before Reboot

Before rebooting or switching to a different target, you might want to check if all the necessary dependencies are in place. For example, ensuring that multi-user.target has all required services before entering multi-user mode can prevent system issues.

systemctl list-dependencies multi-user.target

Conclusion

The systemctl list-dependencies command is an essential tool for system administrators and power users working with systemd in RHEL (Red Hat Enterprise Linux). It allows you to explore the dependency relationships between different systemd units, whether you’re troubleshooting a service or trying to understand how services are linked together under specific system states.

By mastering this command, you can:

  • Troubleshoot service failures by understanding dependencies.
  • Explore system state dependencies for specific targets.
  • Get a comprehensive view of service and target relationships.

Whether you’re diagnosing issues or simply exploring the inner workings of your RHEL system, systemctl list-dependencies is a powerful command that enhances your ability to manage and maintain Linux systems effectively.