How to Create and Run New Service Units in Systemd
Several days ago, I encountered a 32-bit CentOS 8 distribution and decided to test it on an older 32-bit system. Post-boot, I discovered a network connectivity issue; the connection would drop, requiring manual restoration after each reboot. This prompted me to explore automated solutions. This article details how to achieve this using systemd service units.
Before diving into the specifics, let's briefly examine systemd service units and their functionality. We'll cover the fundamentals of systemd service units, their interaction with "targets," and the process of configuring a service unit to execute a script on boot. The focus will be on practical steps.
What are Systemd Service Units?
A systemd service unit is a configuration file defining a service's system behavior. This could encompass network services, applications, or scripts designed to run during boot or at specific boot stages.
These units are organized into targets, representing milestones in the boot process. For instance, upon reaching the multi-user target (runlevel 3), specific services initiate. Consider targets as service "groups" collaborating at various boot phases.
To view services active within a target (e.g., graphical.target), utilize the systemctl
command:
systemctl --type=service
This displays all active services in the current target. Some services run continuously; others execute once and terminate.
Monitoring Service Status
To check a service's status (active or inactive), use systemctl status
:
systemctl status firewalld.service
This command checks firewalld's status. Observe its active (running) and enabled (auto-starts on reboot) states.
Temporarily stop a service (until the next boot) with:
systemctl stop firewalld.service systemctl status firewalld.service
This halts firewalld for the current session but doesn't prevent future restarts.
Enabling and Disabling Services
To ensure a service auto-starts on boot, enable it (creating a symbolic link in the target's "wants" folder):
systemctl enable firewalld.service
Disabling is achieved via:
systemctl disable firewalld.service
Creating a Custom Service Unit
To create a boot-time script service, create a new service unit in /etc/systemd/system
. This directory houses existing service unit files and target folders.
cd /etc/systemd/system ls -l
Create connection.service
using Vim or a similar editor:
vim connection.service
Add the following:
[Unit] Description=Bring up network connection After=network.target [Service] ExecStart=/root/scripts/conup.sh [Install] WantedBy=multi-user.target
Explanation:
-
[Unit]
: Metadata; describes the unit and specifies execution afternetwork.target
(ensuring network initialization). -
[Service]
: Defines the command (conup.sh
script execution). -
[Install]
: Specifies loading at themulti-user.target
.
Enable the service for auto-start on reboot:
systemctl enable connection.service
Verify enabling by checking multi-user.target.wants
:
ls -l multi-user.target.wants/
The connection.service
symbolic link should be present. Now, create the script.
Creating the Script
Create the conup.sh
script to restore the network connection:
cd /root mkdir scripts cd scripts vi conup.sh
Add this line (assuming the interface is enp0s3
):
#!/bin/bash nmcli connection up enp0s3
Make the script executable:
chmod x conup.sh
The service is now ready.
SELinux Considerations (RHEL/CentOS)
On RHEL-based systems (CentOS, Rocky Linux), SELinux might block script execution unless the correct security context is applied.
Temporarily set the context:
chcon -t bin_t /root/scripts/conup.sh
For a permanent solution:
semanage fcontext -a -t bin_t "/root/scripts/conup.sh" restorecon -v /root/scripts/conup.sh
This ensures continued script execution after reboots or SELinux policy updates.
Testing the Service
Test without rebooting by manually starting the service:
systemctl start connection.service
If successful, the network connection should restore. For simpler scripts (e.g., touch /tmp/testbootfile
), check for /tmp/testbootfile
creation to confirm service execution.
Conclusion
This guide provides a comprehensive understanding of systemd service units, their creation, management, and application in automating tasks such as network connection restoration on boot. This enhances system automation and efficiency.
The above is the detailed content of How to Create and Run New Service Units in Systemd. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Linux is best used as server management, embedded systems and desktop environments. 1) In server management, Linux is used to host websites, databases, and applications, providing stability and reliability. 2) In embedded systems, Linux is widely used in smart home and automotive electronic systems because of its flexibility and stability. 3) In the desktop environment, Linux provides rich applications and efficient performance.

The five basic components of Linux are: 1. The kernel, managing hardware resources; 2. The system library, providing functions and services; 3. Shell, the interface for users to interact with the system; 4. The file system, storing and organizing data; 5. Applications, using system resources to implement functions.

Linux system management ensures the system stability, efficiency and security through configuration, monitoring and maintenance. 1. Master shell commands such as top and systemctl. 2. Use apt or yum to manage the software package. 3. Write automated scripts to improve efficiency. 4. Common debugging errors such as permission problems. 5. Optimize performance through monitoring tools.

The methods for basic Linux learning from scratch include: 1. Understand the file system and command line interface, 2. Master basic commands such as ls, cd, mkdir, 3. Learn file operations, such as creating and editing files, 4. Explore advanced usage such as pipelines and grep commands, 5. Master debugging skills and performance optimization, 6. Continuously improve skills through practice and exploration.

Linux is widely used in servers, embedded systems and desktop environments. 1) In the server field, Linux has become an ideal choice for hosting websites, databases and applications due to its stability and security. 2) In embedded systems, Linux is popular for its high customization and efficiency. 3) In the desktop environment, Linux provides a variety of desktop environments to meet the needs of different users.

Linux devices are hardware devices running Linux operating systems, including servers, personal computers, smartphones and embedded systems. They take advantage of the power of Linux to perform various tasks such as website hosting and big data analytics.

The disadvantages of Linux include user experience, software compatibility, hardware support, and learning curve. 1. The user experience is not as friendly as Windows or macOS, and it relies on the command line interface. 2. The software compatibility is not as good as other systems and lacks native versions of many commercial software. 3. Hardware support is not as comprehensive as Windows, and drivers may be compiled manually. 4. The learning curve is steep, and mastering command line operations requires time and patience.

Linuxisfundamentallyfree,embodying"freeasinfreedom"whichallowsuserstorun,study,share,andmodifythesoftware.However,costsmayarisefromprofessionalsupport,commercialdistributions,proprietaryhardwaredrivers,andlearningresources.Despitethesepoten
