自定義 systemctl 管理服務

自定義 systemctl 管理服務

##簡介
systemd是靠管理unit的方式來控制開機服務,開機級別等功能。
在/usr/lib/systemd/system目錄下包含了各種unit文件,有service後綴的服務unit,有target後綴的開機級別unit等,這裏介紹關於service後綴的文件。因爲systemd在開機要想執行自啓動,都是通過這些*.service 的unit控制的,服務又分爲系統服務(system)和用戶服務(user)。

  • 系統服務:開機不登陸就能運行的程序(常用於開機自啓)。
  • 用戶服務:需要登陸以後才能運行的程序。

配置文件說明:

所有的*.service 文件都存放在/lib/systemd/system目錄下面,
我們可以查看 crontab.service 文件看看裏面 寫的都是什麼

[root@zhangsf system]# cd ~
[root@zhangsf ~]# cat /usr/lib/systemd/system/crond.service
[Unit]
Description=Command Scheduler
After=auditd.service systemd-user-sessions.service time-sync.target

[Service]
EnvironmentFile=/etc/sysconfig/crond
ExecStart=/usr/sbin/crond -n $CRONDARGS
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process

[Install]
WantedBy=multi-user.target

可以看出大概分爲如下幾個部分
*[Unit]塊: 啓動順序和依賴關係

Description: 當前服務的簡單介紹
Documentation: 使用文檔的位置 
After: 如果auditd.service或者systemd-user-sessions.service服務需要啓動,應該在這個服務之前啓動
Before: crontd 服務應該在那些服務之前啓動

注意: After 和 Before 只涉及啓動順序,不涉及依賴關係.

[Service]啓動行爲

啓動命令
> ExecStart字段:定義啓動進程時執行的命令
> ExecReload字段:重啓服務時執行的命令
> ExecStop字段:停止服務時執行的命令
> ExecStartPre字段:啓動服務之前執行的命令
> ExecStartPost字段:啓動服務之後執行的命令
> ExecStopPost字段:停止服務之後執行的命令

注:所有的啓動設置之前,都可以加上一個連詞號(-),表示"抑制錯誤",即發生錯誤的時候,不影響其他命令的執行。
比如EnvironmentFile=-/etc/sysconfig/sshd(注意等號後面的那個連詞號),就表示即使
/etc/sysconfig/sshd文件不存在,也不會拋出錯誤。
注意:[Service]中的啓動、重啓、停止命令全部要求使用絕對路徑!

啓動類型
Type字段定義啓動類型。它可以設置的值如下:
> simple(默認值):ExecStart字段啓動的進程爲主進程
> forking:ExecStart字段將以fork()方式啓動,此時父進程將會退出,子進程將成爲主進程(後臺運行)
> oneshot:類似於simple,但只執行一次,Systemd 會等它執行完,才啓動其他服務
> dbus:類似於simple,但會等待 D-Bus 信號後啓動
> notify:類似於simple,啓動結束後會發出通知信號,然後 Systemd 再啓動其他服務
> idle:類似於simple,但是要等到其他任務都執行完,纔會啓動該服務。一種使用場合是爲讓該服務的輸出,不與其他服務的輸出相混合

重啓行爲
Service區塊有一些字段,定義了重啓行爲:
> KillMode字段:定義 Systemd 如何停止 sshd 服務:
> control-group(默認值):當前控制組裏面的所有子進程,都會被殺掉
> process:只殺主進程
> mixed:主進程將收到 SIGTERM 信號,子進程收到 SIGKILL 信號
> none:沒有進程會被殺掉,只是執行服務的 stop 命令。
> Restart字段:定義了 sshd 退出後,Systemd 的重啓方式
上面的例子中,Restart設爲on-failure,表示任何意外的失敗,就將重啓sshd。如果 sshd 正常停止(比如執行systemctl stop命令),它就不會重啓。
>> Restart字段可以設置的值如下。
>> no(默認值):退出後不會重啓
>> on-success:只有正常退出時(退出狀態碼爲0),纔會重啓
>> on-failure:非正常退出時(退出狀態碼非0),包括被信號終止和超時,纔會重啓
>> on-abnormal:只有被信號終止和超時,纔會重啓
>> on-abort:只有在收到沒有捕捉到的信號終止時,纔會重啓
>> on-watchdog:超時退出,纔會重啓
>> always:不管是什麼退出原因,總是重啓
注:對於守護進程,推薦設爲on-failure。對於那些允許發生錯誤退出的服務,可以設爲on-abnormal。
RestartSec字段:表示 Systemd 重啓服務之前,需要等待的秒數。
上面的例子設爲等待42秒。

[install]如何安裝這個配置文件
WantedBy字段:表示該服務所在的 Target。
Target的含義是服務組,表示一組服務。
WantedBy=multi-user.target指的是:sshd 所在的 Target 是multi-user.target。
這個設置非常重要,因爲執行systemctl enable sshd.service命令時,sshd.service的一個符號鏈接,就會放在/etc/systemd/system目錄下面的multi-user.target.wants子目錄之中。
Systemd 有默認的啓動 Target。

systemctl get-default
#輸出multi-user.target

上面的結果表示,默認的啓動 Target 是multi-user.target。在這個組裏的所有服務,都將開機啓動。這就是爲什麼systemctl enable命令能設置開機啓動的原因。
使用 Target 的時候,systemctl list-dependencies命令和systemctl isolate命令也很有用。

#查看 multi-user.target 包含的所有服務
systemctl list-dependencies multi-user.target

#切換到另一個 target
#shutdown.target 就是關機狀態
systemctl isolate shutdown.target

一般來說,常用的 Target 有兩個:
multi-user.target:表示多用戶命令行狀態;
graphical.target:表示圖形用戶狀態,它依賴於multi-user.target。

##舉例

[root@zhangsf system]# cat /usr/lib/systemd/system/node-exporter.service
[Unit]
Description=This is prometheus node exporter
After=docker.service

[Service]
Type=simple
ExecStart=/usr/local/bin/node_exporter
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure

[Install]
WantedBy=multi-user.target

執行命令

systemctl daemon-reload
systemctl enable node-exporter.service
systemctl start node-exporter.service

查看日誌

[root@zhangsf system]# tail -f /var/log/messages
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - sockstat" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - stat" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - textfile" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - time" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - timex" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - uname" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - vmstat" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - xfs" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg=" - zfs" source="node_exporter.go:104"
Feb  6 11:53:40 zhangsf node_exporter: time="2020-02-06T11:53:40+08:00" level=info msg="Listening on :9100" source="node_exporter.go:170"

參考:

https://www.jianshu.com/p/79059b06a121
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章