How to Start, Stop, and Restart Services in Linux

Check out our latest products

Added to wishlistRemoved from wishlist 0
Add to compare
(2-Way Audio & PIR Detection) Dual Antennas Outdoor Wireless Security Camera System 5.5MP Wi-Fi Video Surveillance
Added to wishlistRemoved from wishlist 0
Add to compare
$399.99
Added to wishlistRemoved from wishlist 0
Add to compare
2 | FPV Goggles for All Camera Drones | Unibody Lens | HD FPV Goggles | Compatible Versatile Skyview FPV Drone Goggles | Clear Immersive View | All GPS Camera Drone
Added to wishlistRemoved from wishlist 0
Add to compare
$179.00

For advanced Linux users, starting, stopping, and restarting Linux services is essential. These operations allow users to access the functionality of each service. For example, to use a web server, users need to start the Apache service, or to use a database, users must start the MySQL service. Managing Linux services is also important for system stability and can help improve system performance.

Despite common belief, starting, stopping, and restarting services in Linux is relatively straightforward. We’ll be working with Linux, but all of the commands for starting, stopping and restarting Linux services can be run on CentOS, Ubuntu, Redhat, Fedora, Debian, and many other distributions.

What is the difference between systemctl and service commands?

There are two official management tools that provide a consistent way to start, stop, restart, and manage system services in Linux:

Systemctl offers more advanced functionality, including dependency management, enabling/disabling services, and integration with journalctl for logging. Service is simpler and primarily used for basic service start, stop, and status commands. It is often used with older SysVinit-based systems.

Which one you use will depend on whether your distribution uses systemd or init. Most modern distributions now use systemd, so systemctl is the service manager of choice. But some old habits die hard, so many administrators still hold onto the aging service command.

Fortunately, the developers of systemd made sure to retain service and redirect it to systemctl, so even on systemd-based systems, using service will still work for basic tasks

To complicate matters more, you might find a random service you’ve installed that hasn’t been updated to either the service or systemctl tools and must manually start it with /etc/rc.d (or /etc/init.d).But we’re looking for best practices here, and for starting, stopping, or restarting applications on Linux, best practices begin and end with systemctl.

SEE: Start learning to use Linux for IT and Sysadmin with this bundle

Starting a Linux service

Let’s say you want to start the Apache server.

To do this:

  1. Open a terminal window.
  2. Run the command sudo systemctl start httpd.

In this command:

  • sudo tells Linux you are running the command as the root user.
  • systemctl manages systemd services.
  • start tells the systemctl command to start the Apache service.
  • httpd is the name of the Apache web server service.
  1. Once you run the command you will get the following message:

The service httpd has started successfully.

Note that if the service is already running you will see the following message:

The service httpd is already running.

SEE: How to quickly open a terminal in a specific Linux directory

Common error messages

Failed to start httpd.service. Unit httpd.service not found.

This error occurs if the Apache web server package isn’t installed or the service unit file is missing. Install the Apache package using sudo apt install apache2 (on Debian-based systems) or sudo yum install httpd (on Red Hat-based systems) to resolve it.

Failed to start httpd.service. Address already in use.

This indicates that another process already uses the port Apache wants to bind to (usually port 80). Identify the conflicting process with sudo lsof -i:80 and stop it, or change the port configuration in Apache’s config file.

Stopping a Linux service

To stop the Apache service:

  1. Open a terminal window
  2. Run the command sudo systemctl stop httpd.
  3. You should now see the following message:

The service httpd has been stopped successfully.

Note that if the service, in this case Apache, was not running, you will get the following message:

Failed to stop service httpd. Unit httpd.service is not loaded.

Install it using sudo apt install apache2 (Debian-based) or sudo yum install httpd (Red Hat-based).

Or you may get one of the following messages:

Failed to stop service httpd. Unit httpd.service is not running.

This indicates Apache is already stopped, so no action is needed.

Failed to stop service httpd. Unit httpd.service is in a failed state.

This suggests Apache encountered an error and is in a failed state. To troubleshoot, run sudo journalctl -xe to view detailed logs, then try restarting the service.

Failed to stop service httpd. Unit httpd.service is locked.

This error occurs if another process is controlling the service. Wait briefly and try again, or check for running management tasks with ps aux | grep httpd to identify the locking process.

SEE: Linux 101: How to search for files from the Linux command line

Restarting a Linux service

To restart the same service (Apache):

  1. Open a terminal window.
  2. Run the command sudo systemctl restart httpd.
  3. The service will restart, and you’ll be returned to the bash prompt.
  4. You will get the following message:

The service httpd has been restarted successfully.

Common error messages

If the Apache service isn’t running, you’ll see the following output:

The service httpd is not running.

You can start it directly with sudo systemctl start httpd or check its status with systemctl status httpd.

You may also see the following:

Job for httpd.service failed.

This usually indicates a configuration or dependency issue. To troubleshoot, review the error details with sudo journalctl -xe and correct any configuration issues.

Starting, stopping, and restarting services with service usage

To make matters interesting, the service command still works — even for those distributions that have migrated to systemd and systemctl. This means those who instinctively type service when needing to restart a service on Linux won’t receive an Unknown command error.

SEE: Run a Google search from the Linux command line with Googler

In the case of service, the command will redirect to systemctl. In fact, when you run the service command on a systemctl-enabled distribution, you’ll clearly see the redirect information.

The terminal shows you the redirect information for service commands on systemctl-enabled distributions.

The service command usage is a bit different from systemctl. The service name and start, stop, and restart options are switched:

sudo service httpd start
sudo service httpd stop
sudo service httpd restart

In each case, you’ll see service redirected to systemctl, but the service you are attempting to start, stop, or restart will succeed.

To learn more about what systemctl can do for you, make sure to issue the command man systemctl and give the man page a read.


Added to wishlistRemoved from wishlist 0
Add to compare
’47 MLB Mens Men’s Brand Clean Up Cap One-Size
Added to wishlistRemoved from wishlist 0
Add to compare
$29.95
Added to wishlistRemoved from wishlist 0
Add to compare
(2-Way Audio & PIR Detection) Dual Antennas Outdoor Wireless Security Camera System 5.5MP Wi-Fi Video Surveillance
Added to wishlistRemoved from wishlist 0
Add to compare
$399.99
Added to wishlistRemoved from wishlist 0
Add to compare
[3 Pack] Sport Bands Compatible with Fitbit Charge 5 Bands Women Men, Adjustable Soft Silicone Charge 5 Wristband Strap for Fitbit Charge 5, Large
Added to wishlistRemoved from wishlist 0
Add to compare
$9.99
Added to wishlistRemoved from wishlist 0
Add to compare
[3 Pack] Sport Bands Compatible with Fitbit Charge 5 Bands Women Men, Adjustable Soft Silicone Charge 5 Wristband Strap for Fitbit Charge 5, Small
Added to wishlistRemoved from wishlist 0
Add to compare
$9.99

We will be happy to hear your thoughts

Leave a reply

Best Deals for all new
Logo
Compare items
  • Total (0)
Compare
0
Shopping cart