如何使用 systemctl 管理服務



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!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM