Systemd 入門教程:命令篇

来源:https://www.cnblogs.com/maginaro/archive/2019/10/12/11660269.html
-Advertisement-
Play Games

轉自:http://www.ruanyifeng.com/blog/2016/03/systemd-tutorial-commands.html Systemd 是 Linux 系統工具,用來啟動守護進程,已成為大多數發行版的標準配置。 本文介紹它的基本用法,分為上下兩篇。今天介紹它的主要命令,下一 ...


轉自:http://www.ruanyifeng.com/blog/2016/03/systemd-tutorial-commands.html

 

Systemd 是 Linux 系統工具,用來啟動守護進程,已成為大多數發行版的標準配置。

本文介紹它的基本用法,分為上下兩篇。今天介紹它的主要命令,下一篇介紹如何用於實戰。

一、由來

歷史上,Linux 的啟動一直採用init進程。

下麵的命令用來啟動服務。


$ sudo /etc/init.d/apache2 start
# 或者
$ service apache2 start

這種方法有兩個缺點。

一是啟動時間長。init進程是串列啟動,只有前一個進程啟動完,才會啟動下一個進程。

二是啟動腳本複雜。init進程只是執行啟動腳本,不管其他事情。腳本需要自己處理各種情況,這往往使得腳本變得很長。

二、Systemd 概述

Systemd 就是為瞭解決這些問題而誕生的。它的設計目標是,為系統的啟動和管理提供一套完整的解決方案。

根據 Linux 慣例,字母d是守護進程(daemon)的縮寫。 Systemd 這個名字的含義,就是它要守護整個系統。

(上圖為 Systemd 作者 Lennart Poettering

使用了 Systemd,就不需要再用init了。Systemd 取代了initd,成為系統的第一個進程(PID 等於 1),其他進程都是它的子進程。


$ systemctl --version

上面的命令查看 Systemd 的版本。

Systemd 的優點是功能強大,使用方便,缺點是體系龐大,非常複雜。事實上,現在還有很多人反對使用 Systemd,理由就是它過於複雜,與操作系統的其他部分強耦合,違反"keep simple, keep stupid"的Unix 哲學

(上圖為 Systemd 架構圖)

三、系統管理

Systemd 並不是一個命令,而是一組命令,涉及到系統管理的方方面面。

3.1 systemctl

systemctl是 Systemd 的主命令,用於管理系統。


# 重啟系統
$ sudo systemctl reboot

# 關閉系統,切斷電源
$ sudo systemctl poweroff

# CPU停止工作
$ sudo systemctl halt

# 暫停系統
$ sudo systemctl suspend

# 讓系統進入冬眠狀態
$ sudo systemctl hibernate

# 讓系統進入互動式休眠狀態
$ sudo systemctl hybrid-sleep

# 啟動進入救援狀態(單用戶狀態)
$ sudo systemctl rescue

3.2 systemd-analyze

systemd-analyze命令用於查看啟動耗時。


# 查看啟動耗時
$ systemd-analyze                                                                                       

# 查看每個服務的啟動耗時
$ systemd-analyze blame

# 顯示瀑布狀的啟動過程流
$ systemd-analyze critical-chain

# 顯示指定服務的啟動流
$ systemd-analyze critical-chain atd.service

3.3 hostnamectl

hostnamectl命令用於查看當前主機的信息。


# 顯示當前主機的信息
$ hostnamectl

# 設置主機名。
$ sudo hostnamectl set-hostname rhel7

3.4 localectl

localectl命令用於查看本地化設置。


# 查看本地化設置
$ localectl

# 設置本地化參數。
$ sudo localectl set-locale LANG=en_GB.utf8
$ sudo localectl set-keymap en_GB

3.5 timedatectl

timedatectl命令用於查看當前時區設置。


# 查看當前時區設置
$ timedatectl

# 顯示所有可用的時區
$ timedatectl list-timezones                                                                                   

# 設置當前時區
$ sudo timedatectl set-timezone America/New_York
$ sudo timedatectl set-time YYYY-MM-DD
$ sudo timedatectl set-time HH:MM:SS

3.6 loginctl

loginctl命令用於查看當前登錄的用戶。


# 列出當前session
$ loginctl list-sessions

# 列出當前登錄用戶
$ loginctl list-users

# 列出顯示指定用戶的信息
$ loginctl show-user ruanyf

四、Unit

4.1 含義

Systemd 可以管理所有系統資源。不同的資源統稱為 Unit(單位)。

Unit 一共分成12種。

  • Service unit:系統服務
  • Target unit:多個 Unit 構成的一個組
  • Device Unit:硬體設備
  • Mount Unit:文件系統的掛載點
  • Automount Unit:自動掛載點
  • Path Unit:文件或路徑
  • Scope Unit:不是由 Systemd 啟動的外部進程
  • Slice Unit:進程組
  • Snapshot Unit:Systemd 快照,可以切回某個快照
  • Socket Unit:進程間通信的 socket
  • Swap Unit:swap 文件
  • Timer Unit:定時器

systemctl list-units命令可以查看當前系統的所有 Unit 。


# 列出正在運行的 Unit
$ systemctl list-units

# 列出所有Unit,包括沒有找到配置文件的或者啟動失敗的
$ systemctl list-units --all

# 列出所有沒有運行的 Unit
$ systemctl list-units --all --state=inactive

# 列出所有載入失敗的 Unit
$ systemctl list-units --failed

# 列出所有正在運行的、類型為 service 的 Unit
$ systemctl list-units --type=service

4.2 Unit 的狀態

systemctl status命令用於查看系統狀態和單個 Unit 的狀態。


# 顯示系統狀態
$ systemctl status

# 顯示單個 Unit 的狀態
$ sysystemctl status bluetooth.service

# 顯示遠程主機的某個 Unit 的狀態
$ systemctl -H 7.example.com status httpd.service

除了status命令,systemctl還提供了三個查詢狀態的簡單方法,主要供腳本內部的判斷語句使用。


# 顯示某個 Unit 是否正在運行
$ systemctl is-active application.service

# 顯示某個 Unit 是否處於啟動失敗狀態
$ systemctl is-failed application.service

# 顯示某個 Unit 服務是否建立了啟動鏈接
$ systemctl is-enabled application.service

4.3 Unit 管理

對於用戶來說,最常用的是下麵這些命令,用於啟動和停止 Unit(主要是 service)。


# 立即啟動一個服務
$ sudo systemctl start apache.service

# 立即停止一個服務
$ sudo systemctl stop apache.service

# 重啟一個服務
$ sudo systemctl restart apache.service

# 殺死一個服務的所有子進程
$ sudo systemctl kill apache.service

# 重新載入一個服務的配置文件
$ sudo systemctl reload apache.service

# 重載所有修改過的配置文件
$ sudo systemctl daemon-reload

# 顯示某個 Unit 的所有底層參數
$ systemctl show httpd.service

# 顯示某個 Unit 的指定屬性的值
$ systemctl show -p CPUShares httpd.service

# 設置某個 Unit 的指定屬性
$ sudo systemctl set-property httpd.service CPUShares=500

4.4 依賴關係

Unit 之間存在依賴關係:A 依賴於 B,就意味著 Systemd 在啟動 A 的時候,同時會去啟動 B。

systemctl list-dependencies命令列出一個 Unit 的所有依賴。


$ systemctl list-dependencies nginx.service

上面命令的輸出結果之中,有些依賴是 Target 類型(詳見下文),預設不會展開顯示。如果要展開 Target,就需要使用--all參數。


$ systemctl list-dependencies --all nginx.service

五、Unit 的配置文件

5.1 概述

每一個 Unit 都有一個配置文件,告訴 Systemd 怎麼啟動這個 Unit 。

Systemd 預設從目錄/etc/systemd/system/讀取配置文件。但是,裡面存放的大部分文件都是符號鏈接,指向目錄/usr/lib/systemd/system/,真正的配置文件存放在那個目錄。

systemctl enable命令用於在上面兩個目錄之間,建立符號鏈接關係。


$ sudo systemctl enable .service
# 等同於
$ sudo ln -s '/' '/'

如果配置文件裡面設置了開機啟動,systemctl enable命令相當於激活開機啟動。

與之對應的,systemctl disable命令用於在兩個目錄之間,撤銷符號鏈接關係,相當於撤銷開機啟動。


$ sudo systemctl disable .service

配置文件的尾碼名,就是該 Unit 的種類,比如sshd.socket。如果省略,Systemd 預設尾碼名為.service,所以sshd會被理解成sshd.service

5.2 配置文件的狀態

systemctl list-unit-files命令用於列出所有配置文件。


# 列出所有配置文件
$ systemctl list-unit-files

# 列出指定類型的配置文件
$ systemctl list-unit-files --type=service

這個命令會輸出一個列表。


$ systemctl list-unit-files

UNIT FILE              STATE
chronyd.service        enabled
clamd@.service         static
.service     disabled

這個列表顯示每個配置文件的狀態,一共有四種。

  • enabled:已建立啟動鏈接
  • disabled:沒建立啟動鏈接
  • static:該配置文件沒有[Install]部分(無法執行),只能作為其他配置文件的依賴
  • masked:該配置文件被禁止建立啟動鏈接

註意,從配置文件的狀態無法看出,該 Unit 是否正在運行。這必須執行前面提到的systemctl status命令。


$ systemctl status bluetooth.service

一旦修改配置文件,就要讓 SystemD 重新載入配置文件,然後重新啟動,否則修改不會生效。


$ sudo systemctl daemon-reload
$ sudo systemctl restart httpd.service

5.3 配置文件的格式

配置文件就是普通的文本文件,可以用文本編輯器打開。

systemctl cat命令可以查看配置文件的內容。


$ systemctl cat atd.service

[Unit]
Description=ATD daemon

[Service]
Type=forking
ExecStart=/usr/bin/atd

[Install]
WantedBy=multi-user.target

從上面的輸出可以看到,配置文件分成幾個區塊。每個區塊的第一行,是用方括弧表示的區別名,比如[Unit]。註意,配置文件的區塊名和欄位名,都是大小寫敏感的。

每個區塊內部是一些等號連接的鍵值對。


[Section]
Directive1=value
Directive2=value

. . .

註意,鍵值對的等號兩側不能有空格。

5.4 配置文件的區塊

[Unit]區塊通常是配置文件的第一個區塊,用來定義 Unit 的元數據,以及配置與其他 Unit 的關係。它的主要欄位如下。

  • Description:簡短描述
  • Documentation:文檔地址
  • Requires:當前 Unit 依賴的其他 Unit,如果它們沒有運行,當前 Unit 會啟動失敗
  • Wants:與當前 Unit 配合的其他 Unit,如果它們沒有運行,當前 Unit 不會啟動失敗
  • BindsTo:與Requires類似,它指定的 Unit 如果退出,會導致當前 Unit 停止運行
  • Before:如果該欄位指定的 Unit 也要啟動,那麼必須在當前 Unit 之後啟動
  • After:如果該欄位指定的 Unit 也要啟動,那麼必須在當前 Unit 之前啟動
  • Conflicts:這裡指定的 Unit 不能與當前 Unit 同時運行
  • Condition...:當前 Unit 運行必須滿足的條件,否則不會運行
  • Assert...:當前 Unit 運行必須滿足的條件,否則會報啟動失敗

[Install]通常是配置文件的最後一個區塊,用來定義如何啟動,以及是否開機啟動。它的主要欄位如下。

  • WantedBy:它的值是一個或多個 Target,當前 Unit 激活時(enable)符號鏈接會放入/etc/systemd/system目錄下麵以 Target 名 + .wants尾碼構成的子目錄中
  • RequiredBy:它的值是一個或多個 Target,當前 Unit 激活時,符號鏈接會放入/etc/systemd/system目錄下麵以 Target 名 + .required尾碼構成的子目錄中
  • Alias:當前 Unit 可用於啟動的別名
  • Also:當前 Unit 激活(enable)時,會被同時激活的其他 Unit

[Service]區塊用來 Service 的配置,只有 Service 類型的 Unit 才有這個區塊。它的主要欄位如下。

  • Type:定義啟動時的進程行為。它有以下幾種值。
  • Type=simple:預設值,執行ExecStart指定的命令,啟動主進程
  • Type=forking:以 fork 方式從父進程創建子進程,創建後父進程會立即退出
  • Type=oneshot:一次性進程,Systemd 會等當前服務退出,再繼續往下執行
  • Type=dbus:當前服務通過D-Bus啟動
  • Type=notify:當前服務啟動完畢,會通知Systemd,再繼續往下執行
  • Type=idle:若有其他任務執行完畢,當前服務才會運行
  • ExecStart:啟動當前服務的命令
  • ExecStartPre:啟動當前服務之前執行的命令
  • ExecStartPost:啟動當前服務之後執行的命令
  • ExecReload:重啟當前服務時執行的命令
  • ExecStop:停止當前服務時執行的命令
  • ExecStopPost:停止當其服務之後執行的命令
  • RestartSec:自動重啟當前服務間隔的秒數
  • Restart:定義何種情況 Systemd 會自動重啟當前服務,可能的值包括always(總是重啟)、on-successon-failureon-abnormalon-aborton-watchdog
  • TimeoutSec:定義 Systemd 停止當前服務之前等待的秒數
  • Environment:指定環境變數

Unit 配置文件的完整欄位清單,請參考官方文檔

六、Target

啟動電腦的時候,需要啟動大量的 Unit。如果每一次啟動,都要一一寫明本次啟動需要哪些 Unit,顯然非常不方便。Systemd 的解決方案就是 Target。

簡單說,Target 就是一個 Unit 組,包含許多相關的 Unit 。啟動某個 Target 的時候,Systemd 就會啟動裡面所有的 Unit。從這個意義上說,Target 這個概念類似於"狀態點",啟動某個 Target 就好比啟動到某種狀態。

傳統的init啟動模式裡面,有 RunLevel 的概念,跟 Target 的作用很類似。不同的是,RunLevel 是互斥的,不可能多個 RunLevel 同時啟動,但是多個 Target 可以同時啟動。


# 查看當前系統的所有 Target
$ systemctl list-unit-files --type=target

# 查看一個 Target 包含的所有 Unit
$ systemctl list-dependencies multi-user.target

# 查看啟動時的預設 Target
$ systemctl get-default

# 設置啟動時的預設 Target
$ sudo systemctl set-default multi-user.target

# 切換 Target 時,預設不關閉前一個 Target 啟動的進程,
# systemctl isolate 命令改變這種行為,
# 關閉前一個 Target 裡面所有不屬於後一個 Target 的進程
$ sudo systemctl isolate multi-user.target

Target 與 傳統 RunLevel 的對應關係如下。


Traditional runlevel      New target name     Symbolically linked to...

Runlevel 0           |    runlevel0.target -> poweroff.target
Runlevel 1           |    runlevel1.target -> rescue.target
Runlevel 2           |    runlevel2.target -> multi-user.target
Runlevel 3           |    runlevel3.target -> multi-user.target
Runlevel 4           |    runlevel4.target -> multi-user.target
Runlevel 5           |    runlevel5.target -> graphical.target
Runlevel 6           |    runlevel6.target -> reboot.target

它與init進程的主要差別如下。

(1)預設的 RunLevel(在/etc/inittab文件設置)現在被預設的 Target 取代,位置是/etc/systemd/system/default.target,通常符號鏈接到graphical.target(圖形界面)或者multi-user.target(多用戶命令行)。

(2)啟動腳本的位置,以前是/etc/init.d目錄,符號鏈接到不同的 RunLevel 目錄 (比如/etc/rc3.d/etc/rc5.d等),現在則存放在/lib/systemd/system/etc/systemd/system目錄。

(3)配置文件的位置,以前init進程的配置文件是/etc/inittab,各種服務的配置文件存放在/etc/sysconfig目錄。現在的配置文件主要存放在/lib/systemd目錄,在/etc/systemd目錄裡面的修改可以覆蓋原始設置。

七、日誌管理

Systemd 統一管理所有 Unit 的啟動日誌。帶來的好處就是,可以只用journalctl一個命令,查看所有日誌(內核日誌和應用日誌)。日誌的配置文件是/etc/systemd/journald.conf

journalctl功能強大,用法非常多。


# 查看所有日誌(預設情況下 ,只保存本次啟動的日誌)
$ sudo journalctl

# 查看內核日誌(不顯示應用日誌)
$ sudo journalctl -k

# 查看系統本次啟動的日誌
$ sudo journalctl -b
$ sudo journalctl -b -0

# 查看上一次啟動的日誌(需更改設置)
$ sudo journalctl -b -1

# 查看指定時間的日誌
$ sudo journalctl --since="2012-10-30 18:17:16"
$ sudo journalctl --since "20 min ago"
$ sudo journalctl --since yesterday
$ sudo journalctl --since "2015-01-10" --until "2015-01-11 03:00"
$ sudo journalctl --since 09:00 --until "1 hour ago"

# 顯示尾部的最新10行日誌
$ sudo journalctl -n

# 顯示尾部指定行數的日誌
$ sudo journalctl -n 20

# 實時滾動顯示最新日誌
$ sudo journalctl -f

# 查看指定服務的日誌
$ sudo journalctl /usr/lib/systemd/systemd

# 查看指定進程的日誌
$ sudo journalctl _PID=1

# 查看某個路徑的腳本的日誌
$ sudo journalctl /usr/bin/bash

# 查看指定用戶的日誌
$ sudo journalctl _UID=33 --since today

# 查看某個 Unit 的日誌
$ sudo journalctl -u nginx.service
$ sudo journalctl -u nginx.service --since today

# 實時滾動顯示某個 Unit 的最新日誌
$ sudo journalctl -u nginx.service -f

# 合併顯示多個 Unit 的日誌
$ journalctl -u nginx.service -u php-fpm.service --since today

# 查看指定優先順序(及其以上級別)的日誌,共有8級
# 0: emerg
# 1: alert
# 2: crit
# 3: err
# 4: warning
# 5: notice
# 6: info
# 7: debug
$ sudo journalctl -p err -b

# 日誌預設分頁輸出,--no-pager 改為正常的標準輸出
$ sudo journalctl --no-pager

# 以 JSON 格式(單行)輸出
$ sudo journalctl -b -u nginx.service -o json

# 以 JSON 格式(多行)輸出,可讀性更好
$ sudo journalctl -b -u nginx.serviceqq
 -o json-pretty

# 顯示日誌占據的硬碟空間
$ sudo journalctl --disk-usage

# 指定日誌文件占據的最大空間
$ sudo journalctl --vacuum-size=1G

# 指定日誌文件保存多久
$ sudo journalctl --vacuum-time=1years

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [20191012]組成rowid.txt--//昨天做了拆分rowid的測試,鏈接http://blog.itpub.net/267265/viewspace-2659613/=>[20191011]拆分rowid 2.txt --//今天測試通過 data_object_id , file ,; ...
  • 今天在啟動sshd時,出現瞭如下問題,導致客戶端不能成功連接服務端,不能建立ssh連接: 有兩個提示 Could not load host key: /etc/ssh/ssh_host_rsa_key 和 Could not load host key: /etc/ssh/ssh_host_dsa ...
  • 相信你遇到過這樣的場景,在瀏覽器網頁中點擊QQ圖標咨詢,就能喚起本機的裝的qq或tim,下載百度網盤的資源的時候,點擊鏈接瀏覽器會啟動本地百度雲進行下載。 最近因為項目需要,也要實現類似的操作,不過需求是在界面版的Linux系統上,網上大多數的教程都是Windows版的內容,Linux的講解比較少, ...
  • CentOS8 yum/dnf 配置國內源(臨時) CentOS 8更改了軟體包的安裝程式,取消了 yum 的配置方法,改而使用了dnf 作為安裝程式。雖然改變了軟體包的安裝方式,但是 dnf 還是能相容使用 yum 的配置文件的和命令的使用方法的。不過我並不知道這個相容配置會持續多久和國內的鏡像( ...
  • 解決Windows10 1903版本0xc0000135錯誤! ...
  • 設置root密碼 安裝Chrome 刪除firefox 刪除evolution 資源管理器關閉evolution任務後,刪除/usr/lib/evolution文件 安裝gnome配置工具禁用視窗動畫 安裝dash to dock插件隱藏任務欄dock面板 安裝hide top bar插件隱藏狀態欄 ...
  • <! TOC "關機重啟命令" "基本操作之修改用戶名(Ubuntu)" "查看系統版本號" "查看系統是32位還是64位" "系統進程信息查看" "查看某個埠被占用的情況" "查看磁碟分區使用情況" " 命令" "fdisk" <! /TOC 關機重啟命令 重啟命令 reboot shutdow ...
  • 腳本存放目錄 /etc/init.d/ /etc/init.d/tomcat restart 重啟/etc/init.d/tomcat start 啟動/etc/init.d/tomcat stop 停止 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...