如何使用 Systemctl 管理服務(wù)
本文轉(zhuǎn)載自微信公眾號(hào)「Linux開(kāi)發(fā)那些事兒 」,作者LinuxThings。轉(zhuǎn)載本文請(qǐng)聯(lián)系Linux開(kāi)發(fā)那些事兒公眾號(hào)。
systemd是一個(gè)服務(wù)管理器,目前已經(jīng)成為L(zhǎng)inux發(fā)行版的新標(biāo)準(zhǔn)。它使管理服務(wù)器變得更加容易。了解并利用組成systemd的工具將有助于我們更好地理解它提供的便利性。
systemctl 的由來(lái)
在 centos7 以前使用 service 來(lái)管理服務(wù)的,雖然它使用起來(lái)比較簡(jiǎn)單,但是對(duì)于每一個(gè)服務(wù),都需要我們?nèi)藶榈木帉懩_本來(lái)控制服務(wù)的啟動(dòng)、停止、重啟等,服務(wù)控制得好壞,完全依賴于編寫腳本的人,而且有些腳本會(huì)很長(zhǎng),需要自己處理的情況比較多
比如 /etc/init.d/network 是管理網(wǎng)絡(luò)服務(wù)的腳本,它有250行,而且腳本中邏輯處理還是挺復(fù)雜的
為了解決上述的問(wèn)題,在 centos7 中引入了systemctl服務(wù)管理的工具,它使用固定格式的腳本來(lái)控制服務(wù)的啟停,所以,引入systemctl之后,服務(wù)的管理變得非常簡(jiǎn)單了,服務(wù)的啟動(dòng)、停止、重啟只需要一條命令就可以
下面介紹下如何使用systemctl 來(lái)管理服務(wù)的
開(kāi)機(jī)啟動(dòng)
對(duì)于支持 systemd 的軟件,安裝的時(shí)候,它會(huì)自動(dòng)的在 /usr/lib/systemd/system 目錄添加一個(gè)配置文件
下面以mysql為例來(lái)說(shuō)明如何設(shè)置開(kāi)機(jī)啟動(dòng)
- systemctl enable mysqld
執(zhí)行上面的命令之后,在 /etc/systemd/system/multi-user.target.wants 目錄下添加一個(gè)符號(hào)鏈接,這個(gè)鏈接指向/usr/lib/systemd/system/ 里面的 mysqld.service 文件
設(shè)置開(kāi)機(jī)啟動(dòng)后,需要等下一次開(kāi)機(jī)的時(shí)候,才會(huì)自動(dòng)執(zhí)行 /etc/systemd/system/ 目錄中的文件
如果忘記了一個(gè)服務(wù)有沒(méi)有設(shè)置成開(kāi)機(jī)啟動(dòng),可以使用 systemctl is-enabled 服務(wù)名 來(lái)查看
- [root@ecs-centos-7 ~]# systemctl is-enabled mysqld
- enabled
啟動(dòng)服務(wù)
執(zhí)行 systemctl start 服務(wù)名 可以啟動(dòng)服務(wù),下面還是以mysql為例來(lái)說(shuō)明
- systemctl start mysqld
服務(wù)啟動(dòng)之后,可以執(zhí)行 systemctl status 服務(wù)名 來(lái)檢查服務(wù)是否啟動(dòng)成功
- [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.
上面結(jié)果中各個(gè)字段含義
- Loaded: 配置文件的位置, 這里是 /usr/lib/systemd/system/mysqld.service
- Active:狀態(tài),active (running) 表示啟動(dòng),如果是 inactive (dead) 表示已關(guān)閉
- Docs: 服務(wù)器文檔
- Main PID:主進(jìn)程ID
- CGroup:進(jìn)程組中所有子進(jìn)程
除了使用 systemctl status 服務(wù)名 之外,還可以使用以下的命令來(lái)查看服務(wù)的狀態(tài)
- [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 一開(kāi)始是啟動(dòng)的,所以執(zhí)行 systemctl is-active mysqld 命令顯示 active, 表示mysql處于開(kāi)啟狀態(tài)
當(dāng)關(guān)閉 mysql 服務(wù)之后,執(zhí)行 systemctl is-active mysqld 命令顯示 inactive 表示mysql處于關(guān)閉狀態(tài)
停止服務(wù)
要停止正在運(yùn)行的服務(wù),執(zhí)行 systemctl stop 服務(wù)名 命令
- systemctl stop mysqld
如果想直接重啟服務(wù)的話,執(zhí)行 systemctl restart 服務(wù)名 命令
- systemctl restart mysqld
服務(wù)的配置文件
上面查看 mysqld 的狀態(tài)的時(shí)候知道,它的配置文件位于 /usr/lib/systemd/system/mysqld.service,其他的服務(wù)配置文件也是位于此目錄下,只不過(guò)具體的文件名不一樣
服務(wù)是根據(jù)它的配置來(lái)啟動(dòng)和停止的,我們使用編輯器或者使用 systemctl cat 服務(wù)名 查看服務(wù)的配置文件, 下面我們以 sshd 服務(wù)的配置文件來(lái)說(shuō)明
- [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
配置文件字段說(shuō)明
- Unit:?jiǎn)?dòng)順序單元的依賴關(guān)系
- Description: 服務(wù)描述,描述服務(wù)的一段文字
- Documentation: 服務(wù)的文檔位置
- After: 當(dāng)前服務(wù)在指定的服務(wù)之后啟動(dòng),這里表示 sshd 服務(wù)需要在 network 和
- sshd-keygen 服務(wù)啟動(dòng)之后再啟動(dòng)
- 如果 sshd 服務(wù)需要在指定服務(wù)啟動(dòng)之前啟動(dòng)的話,使用 Before 字段
- Wants: 服務(wù)的依賴,這種依賴是一種弱依賴關(guān)系,在這里表示的是 sshd 和 sshd-keygen
- 存在依賴關(guān)系,但是它們之間是一種弱依賴
- 也就是說(shuō),如果 sshd-keygen 啟動(dòng)失敗了,是不會(huì)影響 sshd 的
- 如果要表示強(qiáng)依賴關(guān)閉,使用 Requires 字段,也即 如果 sshd-keygen 啟動(dòng)失敗 或者退出了,sshd 也必須退出
- Service:服務(wù)的啟動(dòng)命令以及啟動(dòng)參數(shù)
- Type: 啟動(dòng)類型,常用的值如下所示
- - simple 默認(rèn)值,ExecStart字段啟動(dòng)的進(jìn)程為主進(jìn)程
- - forking ExecStart字段將以fork()方式啟動(dòng),此時(shí)父進(jìn)程將會(huì)退出,子進(jìn)程將成為主進(jìn)程
- - notify 類似于simple,啟動(dòng)結(jié)束后會(huì)發(fā)出通知信號(hào),然后 Systemd 再啟動(dòng)其他服務(wù)
- EnvironmentFile:服務(wù)的環(huán)境變量文件,當(dāng)前配置文件可以用 $KEY 的方式引用環(huán)境變量文件中的參數(shù)
- 上面的例子中,sshd 的環(huán)境變量文件是 /etc/sysconfig/sshd
- ExecStart: 啟動(dòng)服務(wù)執(zhí)行的命令
- ExecReload:重啟服務(wù)執(zhí)行的命令
- KillMode:如何停止服務(wù),可能的值有
- - control-group 默認(rèn)值,當(dāng)前的控制組里面的所有進(jìn)程都會(huì)被殺掉
- - process 只殺主進(jìn)程
- - mixed 主進(jìn)程將收到 SIGTERM 信號(hào),子進(jìn)程收到 SIGKILL 信號(hào)
- - 沒(méi)有進(jìn)程會(huì)被殺掉,只是執(zhí)行服務(wù)的 stop 命令
- Restart:服務(wù)因?yàn)楹畏N原因退出才會(huì)重啟服務(wù),可能的值有
- - always 不論服務(wù)因?yàn)楹畏N情況退出,總是重啟
- - on-success 正常退出時(shí)
- - on-failure 非常正常退出時(shí)
- - on-abnormal 被信號(hào)終止和超時(shí)時(shí),才重啟
- - on-abort 只在收到了沒(méi)有捕捉的信號(hào)時(shí),才重啟
- - on-watchdog 超時(shí)退出,才重啟
- 大部分的情況下,設(shè)置為 on-failure 就可以了
- RestartSec: 服務(wù)器重啟前需等待多少秒
- Install:如何安裝配置文件,也即定義如何做到開(kāi)機(jī)啟動(dòng)
WantedBy 字段表示服務(wù)所在的 Target, 這里的 Target 可以理解成一組服務(wù)
WantedBy 的值是一個(gè)或多個(gè) Targe, 當(dāng)前 Unit(單元) 激活時(shí)(enable)符號(hào)鏈接會(huì)放入/etc/systemd/system 目錄下面以 Target 名 + .wants 后綴構(gòu)成的子目錄中
比如:sshd 的 WantedBy 字段值是 multi-user.target, 執(zhí)行 systemctl enable sshd 之后
相當(dāng)于執(zhí)行了 ln -s /usr/lib/systemd/system/sshd.service /etc/systemd/system/multi-user.target.wants/sshd.service 命令
與之對(duì)應(yīng)的,當(dāng)執(zhí)行 systemctl disable sshd 命令之后,會(huì)去掉上圖中兩個(gè)目錄之間的符號(hào)鏈接,相當(dāng)于開(kāi)機(jī)不會(huì)啟動(dòng) sshd 服務(wù)
關(guān)于上圖中配置文件名 sshd.service 的后綴 .service 表示Unit(單元)的種類,如果省略,默認(rèn)的后綴是 .service ,所以 sshd 會(huì)被當(dāng)做 sshd.service
重新加載配置
如果修改了服務(wù)的配置文件,需要重新加載配置文件,然后重啟服務(wù)
- [root@ecs-centos-7 ~]# systemctl daemon-reload
- [root@ecs-centos-7 ~]# systemctl restart mysqld
救援模式
當(dāng)出現(xiàn)系統(tǒng)無(wú)法正常引導(dǎo)的情況時(shí),可以將系統(tǒng)置于救援模式。救援模式提供了用于修復(fù)系統(tǒng)問(wèn)題的單用戶界面。執(zhí)行 systemctl rescue 命令可以進(jìn)入救援模式
- [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!
進(jìn)入救援模式之后,當(dāng)前登陸的其他用戶會(huì)收到一條系統(tǒng)將進(jìn)入救援模式的通知
如下示例所示,上面 root 用戶執(zhí)行了 systemctl rescue 命令,test 用戶收到了如下系統(tǒng)的廣播通知
- [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!