systemctl管理
一、systemctl理解
linux 服务管理的两种方式service和systemctl,期中,service大部分已被systemctl 取代,
systemd是Linux 系统最新的初始化系统(init.d),作用是为了提高系统的启动速度,尽可能启动较少的进程,尽可能更多的进程并发启动。systemd 对应的进程管理命令是systemctl
init 是initialization的缩写,是启动操作系统时第一个进程(process),这个进程随着系统的开启而营业,直到系统关机才退出舞台。
-
/usr/lib/systemd/system #系统服务,开机不需要登陆就能运行的程序(相当于开启自启)
-
/usr/lib/systemd/user #用户服务,需要登录后才能运行的程序
/usr/lib/systemd/目录下又存在两种类型的文件:
-
*.service # 服务unit文件
-
*.target # 开机级别unit
centos7 的每一个服务以.service 结尾,一般分为3部分:[unit]、[service]、[install]
[Unit] # 主要是服务说明
Description=test # 简单描述服务
After=network.target # 表示此服务启动之后的服务
Before=xxx.service #表示需要在某些服务启动之前启动的服务,After和Before字段只涉及启动顺序,不涉及依赖关系。
[Service] # 服务核心区域
Type=forking # 表示后台运行模式。
User=user # 设置服务运行的用户
Group=user # 设置服务运行的用户组
KillMode=control-group # 定义systemd如何停止服务
PIDFile=/usr/local/test/test.pid # 存放PID的绝对路径
Restart=no # 定义服务进程退出后,systemd的重启方式,默认是不重启
ExecStart=/usr/local/test/bin/startup.sh # 服务启动命令,#命令需要绝对路径
ExecStart=/usr/bin/ls #服务终止命令,命令需要绝对路径
PrivateTmp=true # 表示给服务分配独立的临时空间
[Install]
WantedBy=multi-user.target # 多用户
========================================================================================
[Unit] #主要是服务说明
Description=The nginx HTTP and reverse proxy server #简单描述服务
After=network-online.target remote-fs.target nss-lookup.target #表示此服务启动之后的服务
Wants=network-online.target #多用户
[Service]
Type=forking #后台运行
PIDFile=/run/nginx.pid #PID的存放路径
# Nginx will fail to start if /run/nginx.pid already exists but has the wrong
# SELinux context. This might happen when running `nginx -t` from the cmdline.
# https://bugzilla.redhat.com/show_bug.cgi?id=1268621
ExecStartPre=/usr/bin/rm -f /run/nginx.pid #启动服务前执行的命令 #对于nginx,pid代表进程进行,有pid代表有进程。反之,则无。
ExecStartPre=/usr/sbin/nginx -t #启动服务前执行的命令
ExecStart=/usr/sbin/nginx #systemctl start nginx #启动服务
ExecReload=/usr/sbin/nginx -s reload #重载服务
KillSignal=SIGQUIT
TimeoutStopSec=5 #配置等待启动的秒数
KillMode=process #只杀主进程
PrivateTmp=true #表示给服务临时空间
[Install]
WantedBy=multi-user.target # 多用户
type类型
simple(默认):#以Execstart字段启动的进程为主进程
(代理前台运行的进程)#最常用
forking:#Execstart 字段以fox()方式启动,此时父进程将退出,子进程将成为主进程(后台运行),一般都设置为forking(代理后台运行的程序)#最常用
oneshot : #类似于simple,但只执行一次,systemd会等他执行完,才执行其他服务
dbus: #类似于simple,但会等待D—Bus信号后启动
notify: #类似与simple(前台运行) ,但结束后会发出通知信号,然后systemd才启动其他服务
idle: #类似与simple(前台运行),但要等到其他任务都执行完,才启动该服务
EnvironmentFile:指定配置文件,和连词号组合使用,可以避免配置文件不存在的异常。
Environment:
后面接多个不同的shell变量。
例如:
Environment=DATA_DIR=/data/elk
Environment=LOG_DIR=/var/log/elasticsearch
Environment=PID_DIR=/var/run/elasticsearch
EnvironmentFile=-/etc/sysconfig/elasticsearch
连词号(-):在所有启动设置之前,添加的变量字段,都可以加上连词号
表示抑制错误,即发生错误时,不影响其他命令的执行。
比如EnviromentFile=-/etc/sysconfig/xxx表示即使文件不存在,也不会抛异常
Killmode的类型
contorl-group (默认) # 当前控制组里所有的子进程都会被杀掉
process : #只杀主进程
mixed: #主进程将收到SIGTERM(终止进程)信号,子进程将收到SIGKILL(无条件终止)信号
none: # 没有进程会被杀掉,只是执行服务的stop命令
Restart类型
no (默认):#退出后无操作
on-success :#只有正常退出时(退出状态码为0),才会重启
on-failure: #非正常退出时,重启,包括信号终止,和超时
on-abnaomal: #只有信号终止或超时,才会重启
on-abort : #只有在收到没有捕捉到信号终止时,才会重启
on-watchdog: #超市退出时,才会重启
always: #不管什么退出原因,都会重启
#对于守护进程,推荐使用on-failure
RestartSec
表示systemd重启服务之前,需要等待的秒数:RestartSec:30
[Install]部分是服务安装的相关设置,可设置为多用户的
[Install]
WantedBy=multi-user.target
# WantedBy字段:
# multi-user.target: # 表示多用户命令行状态,这个设置很重要
# graphical.target: # 表示图形用户状体,它依赖于multi-user.target
Exec*后面的命令,仅接受‘指令 参数 参数..’格式,不能接受<> |&等特殊字符,很多bash语法也不支持,如果想要支持bash语法,需要设置Tyep=oneshot
# ExecStart: # 启动服务时执行的命令
# ExecReload: # 重启服务时执行的命令
# ExecStop: # 停止服务时执行的命令
# ExecStartPre: # 启动服务前执行的命令
# ExecStartPost:# 启动服务后执行的命令
# ExecStopPost: # 停止服务后执行的命令
# PrivateTmp=True #表示给服务分配独立的临时空间,
# 注意:[Service]部分的启动、重启、停止命令全部要求使用绝对路径,使用相对路径则会报错!
修改配置文件以后,以754的权限保存在/usr/lib/systemd/system目录下,需要重新加载配置文件方可生效 systemctl daemon-reload
这时就可以利用systemctl进行配置了
首先,使用systemctl start [ 服务名(也是文件名)]可测试服务是否可以成功运行,如果不能运行则可以使用systemctl status [服务名(也是文件名)]查看错误信息和其他服务信息,然后根据报错进行修改,直到可以start,如果不放心还可以测试restart和stop命令。
接着,只要使用systemctl enable xxxxx就可以将所编写的服务添加至开机启动即可。
实操
[root@web01 ~]# cat lige.sh
#!/bin/bash
. /etc/init.d/functions
args=$1
fun(){
[ $? -eq 0 ] && action "Nginx $args is " /bin/true || echo "Nginx $args is " /bin/false
}
case $1 in
start)
netstat -lntup|grep ":80\b" &>/dev/null
if [ $? -eq 0 ]
then
echo "Nginx is runing..."
else
/usr/sbin/nginx
fun
fi
;;
stop)
/usr/sbin/nginx -s stop
fun
;;
reload)
/usr/sbin/nginx -s reload
fun
;;
restart)
netstat -lntup|grep ":80\b" &>/dev/null
if [ $? -ne 0 ]
then
/usr/local/nginx/sbin/nginx
[ $? -eq 0 ] && echo "Nginx start is ok" || echo "Nginx start is failed"
else
/usr/local/nginx/sbin/nginx -s stop
[ $? -eq 0 ] && echo "Nginx stop is ok" || echo "Nginx stop is failed"
sleep 2
/usr/local/nginx/sbin/nginx
fun
fi
;;
status)
netstat -lntup|grep ":80\b" &>/dev/null
if [ $? -eq 0 ]
then
echo "Nginx is runing ..."
else
echo "Nginx is not runing ..."
fi
;;
*)
echo "Usage: $0 {start|stop|status|restart|reload}"
exit 2
esac
[root@web01 ~]# chmod +x lige.sh
由于nginx源码包安装无/usr/lib/systemd/system文件,所以, 启动的时候没有办法使⽤systemctl管理
root@web03 system]# vim /usr/lib/systemd/system/nginx.service
[Unit]
Description=Nginx Service
Before=network.target
After=PHP.target
[Service]
Type=forking
PIDFile=/run/nginx.pid
ExecStartPre=/usr/bin/rm -f /run/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecStop=/usr/local/nginx/sbin/nginx -s stop
ExecReload=/usr/local/nginx/sbin/nginx -s reload
Killmode=process
Restart=on-failure
[root@web03 system]# systemctl daemon-reload #重载
[root@web03 system]# systemctl start nginx
Job for nginx.service failed because a timeout was exceeded. See "systemctl status nginx.service" and "journalctl -xe" for details.
#解决报错: cd /usr/local/nginx/conf
把nginx.conf 文件中pid 由/logs/nginx.pid改为/run/nginx.pid
#启动不成功报错原因还有查看http是否占用端口。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人