systemd是一個服務管理器,目前已經成為Linux發行版的新標准。它使管理服務器變得更加容易。了解並利用組成systemd的工具將有助於我們更好地理解它提供的便利性。
systemctl 的由來
在 centos7 以前使用 service 來管理服務的,雖然它使用起來比較簡單,但是對於每一個服務,都需要我們人為的編寫腳本來控制服務的啟動、停止、重啟等,服務控制得好壞,完全依賴於編寫腳本的人,而且有些腳本會很長,需要自己處理的情況比較多
比如 /etc/init.d/network
是管理網絡服務的腳本,它有250行,而且腳本中邏輯處理還是挺復雜的
為了解決上述的問題,在 centos7 中引入了systemctl服務管理的工具,它使用固定格式的腳本來控制服務的啟停,所以,引入systemctl之后,服務的管理變得非常簡單了,服務的啟動、停止、重啟只需要一條命令就可以
下面介紹下如何使用systemctl 來管理服務的
開機啟動
對於支持 systemd 的軟件,安裝的時候,它會自動的在 /usr/lib/systemd/system
目錄添加一個配置文件
下面以mysql為例來說明如何設置開機啟動
systemctl enable mysqld
執行上面的命令之后,在 /etc/systemd/system/multi-user.target.wants
目錄下添加一個符號鏈接,這個鏈接指向 /usr/lib/systemd/system/
里面的 mysqld.service
文件
設置開機啟動后,需要等下一次開機的時候,才會自動執行 /etc/systemd/system/
目錄中的文件
如果忘記了一個服務有沒有設置成開機啟動,可以使用 systemctl is-enabled 服務名
來查看
[root@ecs-centos-7 ~]# systemctl is-enabled mysqld
enabled
啟動服務
執行 systemctl start 服務名
可以啟動服務,下面還是以mysql為例來說明
systemctl start mysqld
服務啟動之后,可以執行 systemctl status 服務名
來檢查服務是否啟動成功
[root@ecs-centos-7 ~]# systemctl status mysqld
● mysqld.service - MySQL Server
Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)
Active: active (running) since 五 2020-12-04 21:51:53 CST; 3 months 9 days ago
Docs: man:mysqld(8)
http://dev.mysql.com/doc/refman/en/using-systemd.html
Main PID: 1053 (mysqld)
CGroup: /system.slice/mysqld.service
└─1053 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid
12月 04 21:51:51 ecs-centos-7.4-64bit-20200212 systemd[1]: Starting MySQL Server...
12月 04 21:51:53 ecs-centos-7.4-64bit-20200212 systemd[1]: Started MySQL Server.
上面結果中各個字段含義
Loaded: 配置文件的位置, 這里是 /usr/lib/systemd/system/mysqld.service
Active:狀態,active (running) 表示啟動,如果是 inactive (dead) 表示已關閉
Docs: 服務器文檔
Main PID:主進程ID
CGroup:進程組中所有子進程
除了使用 systemctl status 服務名
之外,還可以使用以下的命令來查看服務的狀態
[root@ecs-centos-7 ~]# systemctl is-active mysqld
active
[root@ecs-centos-7 ~]# systemctl stop mysqld
[root@ecs-centos-7 ~]# systemctl is-active mysqld
inactive
上面例子中,mysql 一開始是啟動的,所以執行 systemctl is-active mysqld
命令顯示 active
, 表示mysql處於開啟狀態
當關閉 mysql 服務之后,執行 systemctl is-active mysqld
命令顯示 inactive
表示mysql處於關閉狀態
停止服務
要停止正在運行的服務,執行 systemctl stop 服務名
命令
systemctl stop mysqld
如果想直接重啟服務的話,執行 systemctl restart 服務名
命令
systemctl restart mysqld
服務的配置文件
上面查看 mysqld 的狀態的時候知道,它的配置文件位於 /usr/lib/systemd/system/mysqld.service
,其他的服務配置文件也是位於此目錄下,只不過具體的文件名不一樣
服務是根據它的配置來啟動和停止的,我們使用編輯器或者使用 systemctl cat 服務名
查看服務的配置文件, 下面我們以 sshd 服務的配置文件來說明
[root@ecs-centos-7 ~]# systemctl cat sshd
# /usr/lib/systemd/system/sshd.service
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service
[Service]
Type=notify
EnvironmentFile=/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
配置文件字段說明
- Unit:啟動順序單元的依賴關系
Description: 服務描述,描述服務的一段文字
Documentation: 服務的文檔位置
After: 當前服務在指定的服務之后啟動,這里表示 sshd 服務需要在 network 和
sshd-keygen 服務啟動之后再啟動
如果 sshd 服務需要在指定服務啟動之前啟動的話,使用 Before 字段
Wants: 服務的依賴,這種依賴是一種弱依賴關系,在這里表示的是 sshd 和 sshd-keygen
存在依賴關系,但是它們之間是一種弱依賴
也就是說,如果 sshd-keygen 啟動失敗了,是不會影響 sshd 的
如果要表示強依賴關閉,使用 Requires 字段,也即 如果 sshd-keygen 啟動失敗 或者退出了,sshd 也必須退出
- Service:服務的啟動命令以及啟動參數
Type: 啟動類型,常用的值如下所示
- simple 默認值,ExecStart字段啟動的進程為主進程
- forking ExecStart字段將以fork()方式啟動,此時父進程將會退出,子進程將成為主進程
- notify 類似於simple,啟動結束后會發出通知信號,然后 Systemd 再啟動其他服務
EnvironmentFile:服務的環境變量文件,當前配置文件可以用 $KEY 的方式引用環境變量文件中的參數
上面的例子中,sshd 的環境變量文件是 /etc/sysconfig/sshd
ExecStart: 啟動服務執行的命令
ExecReload:重啟服務執行的命令
KillMode:如何停止服務,可能的值有
- control-group 默認值,當前的控制組里面的所有進程都會被殺掉
- process 只殺主進程
- mixed 主進程將收到 SIGTERM 信號,子進程收到 SIGKILL 信號
- 沒有進程會被殺掉,只是執行服務的 stop 命令
Restart:服務因為何種原因退出才會重啟服務,可能的值有
- always 不論服務因為何種情況退出,總是重啟
- on-success 正常退出時
- on-failure 非常正常退出時
- on-abnormal 被信號終止和超時時,才重啟
- on-abort 只在收到了沒有捕捉的信號時,才重啟
- on-watchdog 超時退出,才重啟
大部分的情況下,設置為 on-failure 就可以了
RestartSec: 服務器重啟前需等待多少秒
- Install:如何安裝配置文件,也即定義如何做到開機啟動
WantedBy 字段表示服務所在的 Target, 這里的 Target 可以理解成一組服務
WantedBy 的值是一個或多個 Targe, 當前 Unit(單元) 激活時(enable)符號鏈接會放入/etc/systemd/system
目錄下面以 Target 名
+ .wants
后綴構成的子目錄中
比如:sshd 的 WantedBy 字段值是 multi-user.target, 執行 systemctl enable sshd
之后
相當於執行了 ln -s /usr/lib/systemd/system/sshd.service /etc/systemd/system/multi-user.target.wants/sshd.service
命令
與之對應的,當執行 systemctl disable sshd
命令之后,會去掉上圖中兩個目錄之間的符號鏈接,相當於開機不會啟動 sshd 服務
關於上圖中配置文件名 sshd.service
的后綴 .service
表示Unit(單元)的種類,如果省略,默認的后綴是 .service
,所以 sshd 會被當做 sshd.service
重新加載配置
如果修改了服務的配置文件,需要重新加載配置文件,然后重啟服務
[root@ecs-centos-7 ~]# systemctl daemon-reload
[root@ecs-centos-7 ~]# systemctl restart mysqld
救援模式
當出現系統無法正常引導的情況時,可以將系統置於救援模式。救援模式提供了用於修復系統問題的單用戶界面。執行 systemctl rescue
命令可以進入救援模式
[root@cghost21 ~]# systemctl rescue
PolicyKit daemon disconnected from the bus.
We are no longer a registered authentication agent.
Broadcast message from root@cghost21 on pts/1 (Tue 2021-03-10 20:47:51 CST):
The system is going down to rescue mode NOW!
進入救援模式之后,當前登陸的其他用戶會收到一條系統將進入救援模式的通知
如下示例所示,上面 root
用戶執行了 systemctl rescue
命令,test
用戶收到了如下系統的廣播通知
[test@cghost21 ~]$
Broadcast message from root@cghost21 on pts/1 (Tue 2021-03-10 20:47:51 CST):
The system is going down to rescue mode NOW!