17@linux中将服务加入到systemctl管理系统服务中(脚本)及进程锁的实现

1|0systemctl管理脚本

1|0一、systemctl的简单介绍

systemctl脚本存放在:/usr/lib/systemd/,有系统(system)和用户(user)之分

1|01、服务类型

1)/usr/lib/systemd/system #系统服务,开机不需要登陆就能运行的程序(相当于开启自启) 2)/usr/lib/systemd/user #用户服务,需要登录后才能运行的程序

1|02、文件类型

/usr/lib/systemd/目录下又存在两种类型的文件:

1)*.service #服务unit文件 2)*.target #开机级别unit

1|0二、systemctl文件

centos7 的每一个服务以service 结尾
一般分为3部分:【Unit】、【Service】、【Install】

1|01、文件基础内容注释

[Unit] # 主要是服务说明 Description=test # 简单描述服务 After=network.target # 描述服务类别,表示本服务需要在network服务启动后在启动 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 # 服务启动命令,命令需要绝对路径 PrivateTmp=true # 表示给服务分配独立的临时空间 [Install] WantedBy=multi-user.target # 多用户

1|02、文件字段详解

1|01)Type类型有:
simple(默认): #以Execstart字段启动的进程为主进程 forking: #Execstart 字段以fox()方式启动,,此时父进程将退出,子进程将成为主进程(后台运行),一般都设置为forking oneshot : #类似于simple,但只执行一次,systemd会等他执行完,才执行其他服务 dbus: #类似于simple,但会等待D—Bus信号后启动 notify: #类似与simple ,但结束后会发出通知信号,然后systemd才启动其他服务 idle: #类似与simple,但要等到其他任务都执行完,才启动该服务
1|02)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表示即使文件不存在,也不会抛异常
1|03)Killmode的类型
contorl-group (默认)# 当前控制组里所有的子进程都会被杀掉 process : #只杀主进程 mixed: #主进程将收到SIGTERM(终止进程)信号,子进程将收到SIGKILL(无条件终止)信号 none: # 没有进程会被杀掉,只是执行服务的stop命令
1|04)Restart类型
no (默认): #退出后无操作 on-success :#只有正常退出时(退出状态码为0),才会重启 on-failure: #非正常退出时,重启,包括信号终止,和超时 on-abnaomal: #只有信号终止或超时,才会重启 on-abort : #只有在收到没有捕捉到信号终止时,才会重启 on-watchdog: #超市退出时,才会重启 always: #不管什么退出原因,都会重启 #注:对于守护进程,推荐使用on-failure
1|05)RestartSec

表示systemd重启服务之前,需要等待的秒数:
RestartSec:30

1|06) 各种Exec*字段

Exec*后面的命令,仅接受‘指令 参数 参数…’格式,不能接受<> |&等特殊字符,很多bash语法也不支持,如果想要支持bash语法,需要设置Tyep=oneshot

# ExecStart: # 启动服务时执行的命令 # ExecReload: # 重启服务时执行的命令 # ExecStop: # 停止服务时执行的命令 # ExecStartPre: # 启动服务前执行的命令 # ExecStartPost: # 启动服务后执行的命令 # ExecStopPost: # 停止服务后执行的命令 # PrivateTmp=True #表示给服务分配独立的临时空间, #注意:[Service]部分的启动、重启、停止命令全部要求使用绝对路径,使用相对路径则会报错! [Service] Type=forking PIDFile=/home/developer/web/gunicorn.pid ExecStart=/usr/local/bin/forever start ExecReload=/bin/kill -s HUP $MAINPID ExecStop=/bin/kill -s QUIT $MAINPID PrivateTmp=true
1|07) [Install]部分是服务安装的相关设置,可设置为多用户的
[Install] WantedBy=multi-user.target # WantedBy字段: # multi-user.target: # 表示多用户命令行状态,这个设置很重要 # graphical.target: # 表示图形用户状体,它依赖于multi-user.target

1|03、服务加入使用流程要点

#利用systemctl进行配置文件 1)使用 **systemctl start xxx [服务名(也是文件名)]**可测试服务是否可以成功运行,如果不能运行则可以使用 **systemctl status [服务名(也是文件名)]**查看错误信息和其他服务信息,然后根据报错进行修改,直到可以start,如果不放心还可以测试restart和stop命令 2)将服务使用 **systemctl enable xxx**(服务名称) 就可以将所编写的服务添加至开机启动即可。 3) 修改配置文件以后,以754的权限保存在/usr/lib/systemd/system目录下,需要重新加载配置文件方可生效 #**systemctl daemon-reload**

1|0三、实操

1|01、编写服务启动脚本(nginx)

[root@aliyun ~]# cat nginx.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 ":8080\b" &>/dev/null if [ $? -eq 0 ] then echo "Nginx is runing..." else /usr/local/nginx/sbin/nginx fun fi ;; stop) /usr/local/nginx/sbin/nginx -s stop fun ;; reload) /usr/local/nginx/sbin/nginx -s reload fun ;; restart) netstat -lntup|grep ":8800\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 ":8080\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@aliyun ~]# chmod +x nginx.sh #授予执行权限

1|02、配置服务文件

[root@aliyun ~]# cat /usr/lib/systemd/system/nginx.service [Unit] Description=Nginx server daemon [Service] Type=forking ExecStart=/root/nginx.sh start ExecStop=/root/nginx.sh stop ExecReload=/root/nginx.sh reload PrivateTmp=true [Install] WantedBy=multi-user.target

1|03、服务文件重载

**systemctl daemon-reload**

1|03、检查测试服务状态

[root@aliyun ~]# systemctl start nginx [root@aliyun ~]# systemctl status nginx ● nginx.service - Nginx server daemon Loaded: loaded (/usr/lib/systemd/system/nginx.service; disabled; vendor preset: disabled) Active: active (running) since Mon 2020-08-24 00:10:44 CST; 1s ago Process: 4166 ExecStart=/root/nginx.sh start (code=exited, status=0/SUCCESS) Main PID: 4173 (nginx) CGroup: /system.slice/nginx.service ├─4173 nginx: master process /usr/local/nginx/sbin/nginx └─4175 nginx: worker process Aug 24 00:10:44 aliyun systemd[1]: Starting Nginx server daemon... Aug 24 00:10:44 aliyun nginx.sh[4166]: Nginx start is [ OK ] Aug 24 00:10:44 aliyun systemd[1]: Started Nginx server daemon. [root@aliyun ~]# systemctl reload nginx [root@aliyun ~]# systemctl status nginx ● nginx.service - Nginx server daemon Loaded: loaded (/usr/lib/systemd/system/nginx.service; disabled; vendor preset: disabled) Active: active (running) since Mon 2020-08-24 00:10:44 CST; 13s ago Process: 4186 ExecReload=/root/nginx.sh reload (code=exited, status=0/SUCCESS) Process: 4166 ExecStart=/root/nginx.sh start (code=exited, status=0/SUCCESS) Main PID: 4173 (nginx) CGroup: /system.slice/nginx.service ├─4173 nginx: master process /usr/local/nginx/sbin/nginx └─4193 nginx: worker process Aug 24 00:10:44 aliyun systemd[1]: Starting Nginx server daemon... Aug 24 00:10:44 aliyun nginx.sh[4166]: Nginx start is [ OK ] Aug 24 00:10:44 aliyun systemd[1]: Started Nginx server daemon. Aug 24 00:10:56 aliyun systemd[1]: Reloading Nginx server daemon. Aug 24 00:10:56 aliyun nginx.sh[4186]: Nginx reload is [ OK ] Aug 24 00:10:56 aliyun systemd[1]: Reloaded Nginx server daemon. [root@aliyun ~]#

1|0四、实列

#添加脚本sync.sh到**systemctl**管理 #!/bin/bash case $1 in start) ps -ef|grep [s]ersync &>/dev/null if [ $? -eq 0 ] then action "sersync is running..." /bin/true else /usr/local/sersync/bin/sersync -dro /usr/local/sersync/conf/confxml.xml &>/dev/null [ $? -eq 0 ] && action "sersync start is " /bin/true || action "sersync start is" /bin/false fi ;; stop) ps -ef|grep [s]ersync &>/dev/null if [ $? -eq 0 ] then Pid_num=$(ps -ef|grep [s]ersync|awk '{print $2}') kill $Pid_num ps -ef|grep [s]ersync &>/dev/null [ $? -ne 0 ] && action "sersync stop is" /bin/true || action "sersync stop is" /bin/false else action "sersync is not runing ... " /bin/false fi esac #重载服务文件 **systemctl daemon-reload** #测试添加服务的状态 **systemctl start sersync** **systemctl stop sersync**

1|0五、进程锁

防止进程被重复运行

[root@hzl ~]# cat lock.sh #!/bin/bash lock_file=/tmp/echo1.lock #判断进程是否正在运行 if [ -f $lock_file ];then pid=`cat $lock_file` ps $pid &>/dev/null [ $? -eq 0 ] && echo "Script1 is running..." && exit 1 #if [ $? -eq 0 ];then # echo "Script1 is running..." # exit 1 #fi fi #创建锁 **echo $$ > $lock_file** echo "lock1 begin..." sleep 500 echo "lock1 end" #释放锁 **rm -rf $lock_file**

__EOF__

本文作者ଲ小何才露煎煎饺
本文链接https://www.cnblogs.com/zeny/p/15121511.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   ଲ小何才露煎煎饺  阅读(223)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
点击右上角即可分享
微信分享提示