How to Enable/Disable Services on Ubuntu Systemd. (Update !!!)
What is Systemd and Why should you Care?
Systemd is a init system (first process started during booting) and a system manager providing a standard provides a standard process for controlling what programs run when a Linux system boots up. While systemd is compatible with SysV and Linux Standard Base (LSB) init scripts, systemd is meant to be a drop-in replacement for these older ways of getting a Linux system running. Systemd does more than starting the core programs running. It also starts a journal of system activity, manages services, automounts filesystems, logs events, set up a hostname, and other system tasks. That may sound good to you, but some developers hate it.
Manage Services
The main role of an init system is to set up all the components that need to be started once the kernel has been booted and manage services and daemons. It is itself a daemon process that continues running until the system is shut down.
For service management tasks, Systemd uses the concept of units, which can be services, sockets, mount points, devices, etc. Units are defined using text files in ini format. These files include information about the unit, its settings, and commands to execute. The unit file type is determined by the filename extensions. For ie. (.service), (.mount), (.device) and (.socket).
However, for most service management tasks, you may omit the .service suffix since Systemd is clever enough to recognize that you're presumably trying to operate on a service.
Mount points will automatically be translated into the appropriate .mount unit. For example, specifying /home is equivalent to home.mount. Similar to mount points, devices are automatically translated into the appropriate .device unit, therefore specifying /dev/sda2 is equivalent to dev-sda2.device.
Systemctl, on the other hand, is a command-line program for managing services and controlling Systemd. It is a component of the Systemd ecosystem, and it is installed by default on all systems.
List Current Units
We can use the list-units --type service --all
command to obtain a list of all active units that systemd is aware of.
$sudo systemctl list-units --type service --all
OUTPUT
UNIT LOAD ACTIVE SUB DESCRIPTION
apparmor.service loaded active exited Load AppArmor profiles
apport-autoreport.service loaded inactive dead Process error reports when automatic reporting is en
apport.service loaded active exited LSB: automatic crash report generation
apt-daily-upgrade.service loaded inactive dead Daily apt upgrade and clean activities
apt-daily.service loaded inactive dead Daily apt download activities
● auditd.service not-found inactive dead auditd.service
Here the output has the above columns:
- UNIT: The
systemd
unit name - LOAD: Whether the unit’s configuration has been parsed by
systemd
. The configuration of loaded units is kept in memory. - ACTIVE: A summary state about whether the unit is active or not. This is usually a fairly basic way to tell if the unit has started successfully or not.
- SUB: This is a lower-level state that indicates more detailed information about the unit. This often varies by unit type, state, and the actual method in which the unit runs.
- DESCRIPTION: A short textual description of what the unit is/does.
How to Enable and Disable Services in Systemd init
To start a service in systemd run the command as follow:
$ sudo systemctl start service-name
for instance; to start apache web service, run
$ sudo systemctl start apache2
to verify that the service is running:
$ sudo systemctl status apache2
OUTPUT
apache2.service - The Apache HTTP Server
Loaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor preset: enabled)
Active: active (running) since Wed 2021-06-09 09:24:14 UTC; 1 day 2h ago
Docs: https://httpd.apache.org/docs/2.4/
Main PID: 3015 (apache2)
Tasks: 55 (limit: 2101)
CGroup: /system.slice/apache2.service
├─ 3015 /usr/sbin/apache2 -k start
├─98358 /usr/sbin/apache2 -k start
└─98359 /usr/sbin/apache2 -k start
Jun 09 09:24:03 WebServer systemd[1]: Starting The Apache HTTP Server...
Jun 09 09:24:14 WebServer systemd[1]: Started The Apache HTTP Server.
Jun 10 00:00:03 WebServer systemd[1]: Reloading The Apache HTTP Server.
Jun 10 00:00:04 WebServer systemd[1]: Reloaded The Apache HTTP Server.
Notice that the dot ("●") uses color on supported terminals to summarize the unit state at a glance.
White color indicates an "inactive" or "deactivating" state.
Red color indicates a "failed" or "error" state.
Green indicates an "active", "reloading" or "activating" state.
To Stop the Service
$ sudo systemctl stop apache2
Confirm that the service is not running
$ sudo systemctl stop apache2
OUTPUT
● apache2.service - The Apache HTTP Server
Loaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor preset: enabled)
Active: inactive (dead) since Thu 2021-06-10 12:12:58 UTC; 2s ago
Docs: https://httpd.apache.org/docs/2.4/
Process: 315777 ExecStop=/usr/sbin/apachectl stop (code=exited, status=0/SUCCESS)
Main PID: 3015 (code=exited, status=0/SUCCESS)
Jun 09 09:24:03 WebServer systemd[1]: Starting The Apache HTTP Server...
Jun 09 09:24:14 WebServer systemd[1]: Started The Apache HTTP Server.
Jun 10 00:00:03 WebServer systemd[1]: Reloading The Apache HTTP Server.
Jun 10 00:00:04 WebServer systemd[1]: Reloaded The Apache HTTP Server.
Jun 10 12:12:57 WebServer systemd[1]: Stopping The Apache HTTP Server...
Jun 10 12:12:58 WebServer systemd[1]: apache2.service: Succeeded.
Jun 10 12:12:58 WebServer systemd[1]: Stopped The Apache HTTP Server.
Enable apache2 Service on bootup
$ sudo systemctl enable apache2
Disable apache2 Service on bootup
$ sudo systemctl disable apache2
Restart the Service
$ sudo systemctl restart apache2
Alternatively, if you also wish to enable and start the service at the same time you may execute
$ sudo systemctl enable -- now apache2
To Check whether the Service is currently configured to Start on the next bootup
$ sudo systemctl is-enabled apache2
OUPUT
enabled
To Check whether the Service is active
$ sudo systemctl is-active apache2
OUTPUT
active
How to remove Systemd Services completely (Bonus)
What if you installed a package, and later decide that you no longer need it.
How do you go about removing it completely?
First, stop the service
$ sudo systemctl stop service-name
Second, disable the service
$ sudo systemctl disable service-name
Removing the service in systemd
$ sudo rm /etc/systemd/system/service-name
$ sudo rm /etc/systemd/system/service-name/[related symlinks]
Reload systemd
$ sudo systemctl daemon-reload
Then, run reset-failed to reset any units from failed state
$ sudo systemctl reset-failed
You should be familiar with the systemctl command's fundamental features, which enable you to interface with and control your systemd instance.
While systemctl primarily manages the core systemd process, it also manages various components of the systemd ecosystem.
Also, other features, such as log management and user sessions, are handled by separate daemons and administration programs (journald/journalctl and logind/loginctl).
Taking the effort to become acquainted with these additional tools and daemons will make management easier and effective.