一 介紹
1.systemctl腳本存放在:/usr/lib/systemd/,有系統(system)和用戶(user)之分
1)/usr/lib/systemd/system #系統服務,開機不需要登陸就能運行的程序(相當于開啟自啟)
2)/usr/lib/systemd/user #用戶服務,需要登錄后才能運行的程序
2./usr/lib/systemd/目錄下又存在兩種類型的文件:
1).service # 服務unit文件
2).target # 開機級別unit
centos7 的每一個服務以。service 結尾,一般分為3部分:【unit】、【service】、【install】字段詳細說明
[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、Type類型有:
simple(默認):#以Execstart字段啟動的進程為主進程
forking:#Execstart 字段以fox()方式啟動,,此時父進程將退出,子進程將成為主進程(后臺運行),一般都設置為forking
oneshot : #類似于simple,但只執行一次,systemd會等他執行完,才執行其他服務
dbus: #類似于simple,但會等待D—Bus信號后啟動
notify: #類似與simple ,但結束后會發出通知信號,然后systemd才啟動其他服務
idle: #類似與simple,但要等到其他任務都執行完,才啟動該服務
2、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表示即使文件不存在,也不會拋異常
3、Killmode的類型
contorl-group (默認) # 當前控制組里所有的子進程都會被殺掉
process : #只殺主進程
mixed: #主進程將收到SIGTERM(終止進程)信號,子進程將收到SIGKILL(無條件終止)信號
none: # 沒有進程會被殺掉,只是執行服務的stop命令
4、Restart類型
no (默認):#退出后無操作
on-success :#只有正常退出時(退出狀態碼為0),才會重啟
on-failure: #非正常退出時,重啟,包括信號終止,和超時
on-abnaomal: #只有信號終止或超時,才會重啟
on-abort : #只有在收到沒有捕捉到信號終止時,才會重啟
on-watchdog: #超市退出時,才會重啟
always: #不管什么退出原因,都會重啟
#對于守護進程,推薦使用on-failure
5、RestartSe
表示systemd重啟服務之前,需要等待的秒數:RestartSec:30
6、各種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
7、[Install]部分是服務安裝的相關設置,可設置為多用戶的
[Install]
WantedBy=multi-user.target
# WantedBy字段:
# multi-user.target: # 表示多用戶命令行狀態,這個設置很重要
# graphical.target: # 表示圖形用戶狀體,它依賴于multi-user.target
修改配置文件以后,以754的權限保存在/usr/lib/systemd/system目錄下,需要重新加載配置文件方可生效
$ systemctl daemon-reload
這時就可以利用systemctl進行配置了
首先,使用systemctl start [服務名(也是文件名)]可測試服務是否可以成功運行,如果不能運行則可以使用systemctl
status
[服務名(也是文件名)]查看錯誤信息和其他服務信息,然后根據報錯進行修改,直到可以start,如果不放心還可以測試restart和stop命令。
接著,只要使用systemctl enable xxxxx就可以將所編寫的服務添加至開機啟動即可。
二 實操
編寫腳本如下,并且保證腳本有可執行權限
[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
配置
[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
重新加載
systemctl daemon-reload
測試
[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 ~]#
三 練習
把下述腳本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
|