技术分享
🗒️Systemctl使用总结
00 min
2024-10-13
2024-11-23
type
status
date
slug
summary
tags
category
icon
password
If you are using any popular Linux distribution including Debian, Ubuntu, Arch, openSUSE, or Fedora, your system uses systemd as its init system.
Sure, there are controversies surrounding systemd. But, it is the most used init system.
In a systemd-equipped distro, there is a command that could make your life easy. It is the systemctl command, used to interact with the systemd init service. System administrators always use this command, but it is also useful for end-users wishing to take control via the terminal.
For instance, you can use the systemctl command to list services in Linux.
So in this tutorial, I will walk you through all the essentials you need to learn to use the systemctl command:
  • The basic syntax and common flags.
  • Practical examples of the command.
  • Practice questions to get better at using the systemctl command.

Here's How to Use The Systemctl Command

To use the systemctl command, it is important to learn the syntax and available options.
Here's how the syntax looks like:
Here,
  • <command>: this is where you specify the action you want to execute over the service such as stopstart, etc.
  • <service_name>: this is where you specify the name of the service that you would like to work with.
To manage services, you have various commands to use with the systemctl command, here's a list of one of the most useful ones:
Command
Description
systemctl start [service]
Start a service and run it in the background.
systemctl stop [service]
Stop a currently running service.
systemctl enable [service]
Configure a service to start automatically at system boot.
systemctl disable [service]
Configure a service to not start automatically at system boot.
systemctl status [service]
Display the current status (running, stopped, etc.) of a service.
systemctl restart [service]
Stop a running service and then start it again.
systemctl reload [service]
Reload the configuration of a service without stopping it.
systemctl mask [service]
Prevent a service from being started, even manually.
systemctl unmask [service]
Allow a previously masked service to be started.
systemctl set-default [target]
Change the default system target (runlevel) for the next boot.
systemctl list-unit-files
List all installed unit files and their current state (enabled/disabled).
systemctl list-dependencies [unit]
Show the dependencies (other units) required for a specific unit.
systemctl list-sockets
List all active sockets (for inter-process communication).
systemctl list-jobs
Show all currently active systemd jobs (ongoing operations).
systemctl list-units
List all loaded and active systemd units (services, sockets, etc.).
Now, let's take a look at some practical examples of the systemctl command.

Practical examples of the systemctl command

In this section, I share some practical examples of the systemctl command, ranging from the basics to the advanced ones.
Let's start with how you can start your service.

1. Start a service

In most cases, the installed service gets activated by default, but there are times when you are required to do that manually.
To start a service, you need to use the start flag with the systemctl command and append the name of the service, as shown here:
Let's say I want to start the Apache server, I'll be using the following:
notion image

2. Enable a service

When you start a service, it will only be effective until the next boot. This means the service will be turned off when you reboot your system.
To tackle this situation, you want a service to start automatically when you boot your system and for that purpose, you can use the enable flag as shown here:
For example, if I want to enable Apache service, then I'll use the following:
notion image

3. Stop a service

When you intend to modify an active service, the first step you have to perform is to stop the service and for that purpose, you use the stop flag as shown here:
For example, here's how you stop the Apache service:
notion image
Suggested Read 📖

4. Disable a service

If you've enabled a service in the past, and now you don't want it to be active at every system boot, you can disable it.
To disable a service, you use the disable flag as shown here:
To disable the Apache service, I use the following command:
notion image

5. Check the status of a service

Checking the status before performing any action over a service is highly recommended and can save you a lot of time.
To check the status of a service, all you have to do is append the name of the service to the status flag as shown here:
Here, I check the status of the Apache service:
notion image
As I disabled the Apache service earlier, the above output suggests that the service is disabled.
But depending on your service, you may receive a different status of the service, and here's what it means:
Status
Description
active (running)
The service is currently running in the background.
active (exited)
The service was a one-time or periodic task that has completed its execution.
active (waiting)
The service is running but waiting for a specific event or condition to occur before proceeding.
inactive
The service is not currently running.
enabled
The service is configured to start automatically when the system boots up.
disabled
The service is configured to not start automatically at system boot.
static
This service cannot be managed by systemd or the systemctl command; it needs to be managed manually.
masked
The service is masked, which means it is prevented from being started (needs to be unmasked before it can run).
alias
The service name is an alias, and the service is a symbolic link pointing to another unit file.
linked
The service or unit file is symbolically linked to another unit file.

6. Restart a service

Once you modify the service configuration, or if it is not responding, then restarting a service can be helpful.
To restart a service, you use the restart flag as shown here:
For example, my Apache server was not responding, so if I were to restart the service, then I use the following command:

7. Reload a service

You reload a service when you make changes to the service configuration, and you want to apply changes without restarting the entire service.
To reload a service, you use the reload flag as shown here:
For example, I made a few changes to the Apache service and now if I were to reload the Apache service, here is what I type in the terminal:

8. Mask a service

Masking a service is the most efficient way to prevent that service from being started, either manually or automatically, during system boot.
Think of it as a more robust version of stopping the service 😉.
To mask a service, you use the mask flag as shown here:
Here's how the command would look for the Apache service:
notion image
Whenever you mask the service, you see a symlink created which redirects the service's configuration file to the null device (/dev/null). This means you cannot start the service by any means until it is unmasked.

9. Unmask a service

If you want to start the masked service, it needs to be unmasked first!
To unmask a service, you use the unmask flag as shown here:
Just type in the command like this:
notion image
As you can see, it removed the symlink pointing to /dev/null.

10. Set the default target

Setting a default target refers to changing the default operational mode or runlevel that the system will enter after booting up.
One good example of setting a default target is to choose the user interface to boot, such as you can either boot to CLI mode or GUI.
To set a default target, you use the set-default flag as shown here:
For example, if you want to boot into the GUI, then I will set the default target to graphical.target as shown here:
Apart from the GUI target, you have other options as well:
Target
Description
multi-user.target
This target starts the system with networking enabled, suitable for servers or non-graphical workstations.
rescue.target
This target is useful for system recovery or troubleshooting when the system cannot boot into the regular multi-user mode.
emergency.target
This target provides an emergency environment for system maintenance or repair when the system is in a critically broken state.
reboot.target
This is typically used for one-time reboots or in automated scripts.
poweroff.target
This is typically used for one-time shutdowns or in automated scripts.
hibernate.target
Sets the system to hibernate (save system state to disk and power off) as the default target, Only available if the system supports hibernation.
hybrid-sleep.target
Sets the system to enter a hybrid sleep mode (a combination of hibernation and sleep) as the default target, Only available if the system supports hybrid sleep.

11. List unit files

Unit files are plain text configuration files that are used to define and manage system services and units.
You can list all the unit files by executing the following command:
notion image

12. List of all active sockets

When you list all the active sockets, you get insight into the inter-process communication channels established on a systemd-based system.
To list all the active sockets, use the given command:
notion image
And there you have a list of all the sockets which are listening for the incoming requests.
 

Comments
  • Twikoo