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是否佔用埠。