国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Linux|Centos|Ubuntu|系統進程|Fedora|注冊表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服務器之家 - 服務器系統 - Linux - linux systemctl命令詳解

linux systemctl命令詳解

2022-03-03 17:18sparkdev Linux

這篇文章主要介紹了linux systemctl命令詳解,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

筆者在前文中概要的介紹了 systemd 的基本概念和主要特點。由于 systemd 相關的絕大多數任務都是通過 systemctl 命令管理的,所以本文將集中的介紹 systemctl 命令的用法。注意,本文以 ubuntu 16.04 進行介紹,文中所有的 demo 都在 ubuntu 16.04 中完成。

systemctl 命令有兩大類功能:

  1. 控制 systemd 系統
  2. 管理系統上運行的服務

在介紹這些功能前讓我們先來熱個身,了解些 systemctl 命令自身相關的信息。

預熱

檢查 systemd 的版本

?
1
$ systemctl --version

linux systemctl命令詳解

查看 systemd 和 systemctl 程序相關的目錄

?
1
2
$ whereis systemd
$ whereis systemctl

linux systemctl命令詳解

確認 1 號進程

作為 init 系統,systemd 進程作為系統中的 1 號進程應該是毋庸置疑的,讓我們搜索與 systemd 相關的進程:

linux systemctl命令詳解

結果讓人有點不敢相信自己的眼睛,我們搜到了好幾個與 systemd 相關的進程,但是卻沒有 1 號進程。讓我們看看 1 號進程是誰:

linux systemctl命令詳解

/sbin/init 是什么?

linux systemctl命令詳解

好吧,/sbin/init 只是到 /lib/systemd/systemd 的鏈接文件,系統的 1 號進程的確是 systemd,只不過在 ubuntu 系統中被起了個別名叫 /sbin/init。

管理單個 unit

systemctl 提供了一組子命令來管理單個的 unit,其命令格式為:
systemctl [command] [unit]
command 主要有:
start:立刻啟動后面接的 unit。
stop:立刻關閉后面接的 unit。
restart:立刻關閉后啟動后面接的 unit,亦即執行 stop 再 start 的意思。
reload:不關閉 unit 的情況下,重新載入配置文件,讓設置生效。
enable:設置下次開機時,后面接的 unit 會被啟動。
disable:設置下次開機時,后面接的 unit 不會被啟動。
status:目前后面接的這個 unit 的狀態,會列出有沒有正在執行、開機時是否啟動等信息。
is-active:目前有沒有正在運行中。
is-enable:開機時有沒有默認要啟用這個 unit。
kill :不要被 kill 這個名字嚇著了,它其實是向運行 unit 的進程發送信號。
show:列出 unit 的配置。
mask:注銷 unit,注銷后你就無法啟動這個 unit 了。
unmask:取消對 unit 的注銷。

我們先通過 prometheus.service 來觀察服務類型 unit 的基本信息:

linux systemctl命令詳解

輸出內容的第一行是對 unit 的基本描述。
第二行中的 loaded 描述操作系統啟動時會不會啟動這個服務,enabled 表示開機時啟動,disabled 表示開機時不啟動。而啟動該服務的配置文件路徑為:/lib/systemd/system/prometheus.service。
第三行 中的 active 描述服務當前的狀態,active (running) 表示服務正在運行中。如果是 inactive (dead) 則表示服務當前沒有運行。后面則是服務的啟動時間。
第四行的 docs 提供了在線文檔的地址。
下面的 main pid 表示進程的 id,接下來是任務的數量,占用的內存和 cpu 資源。
再下面的 cgroup 描述的是 cgrpup 相關的信息,筆者會在后續的文章中詳細的介紹。
最后是輸出的日志信息。

關于 unit 的啟動狀態,除了 enable 和 disable 之外還有:
static:這個 unit 不可以自己啟動,不過可能會被其它的 enabled 的服務來喚醒。
mask:這個 unit 無論如何都無法被啟動!因為已經被強制注銷。可通過 systemctl unmask 改回原來的狀態。

關于 unit 的運行狀態 active,除了 active 和 inactive 之外還有:
active (exited):僅執行一次就正常結束的服務,目前并沒有任何程序在系統中執行。舉例來說,開機或者是掛載時才會進行一次的 quotaon 功能,就是這種模式! quotaon 不需要一直執行,只在執行一次之后,就交給文件系統去自行處理。通常用 bash shell 寫的小型服務,大多是屬于這種類型。
active (waiting):正在執行當中,不過還再等待其他的事件才能繼續處理。舉例來說,打印的相關服務就是這種狀態。

enable 和 disable 操作

比如我們為 prometheus 服務創建了配置文件 /lib/systemd/system/prometheus.service,然后執行 enable 命令:

?
1
$ sudo systemctl enable prometheus.service

linux systemctl命令詳解

所謂的 enable 就是在 multi-user.target.wants 下面創建了一個鏈接文件:

linux systemctl命令詳解

至于為什么會鏈接到 multi-user.target.wants 目錄下,則是由 prometheus.server 文件中的配置信息決定的。

查看 unit 的配置

使用 show 子命令可以查看 unit 的詳細配置情況:

?
1
$ sudo systemctl show prometheus.service

linux systemctl命令詳解

這里的輸出非常多,主要是很多的默認設置也都顯示出來了。

注銷與反注銷 unit

如果我們想暫時的禁用某個 unit,比如 prometheus.service,可以注銷這個 unit,注銷之后就無法再啟動這個服務了:

?
1
$ sudo systemctl mask prometheus.service

linux systemctl命令詳解

從上圖中的輸出我們可以看到,所謂的注銷就是把 prometheus.service 文件鏈接到 /dev/null 這個空設備中去了。所以就無法再啟動該服務了。下面我們嘗試執行一次反注銷:

?
1
$ sudo systemctl unmask prometheus.service

linux systemctl命令詳解

unmask 操作就是刪除掉 mask 操作中創建的鏈接。

查看系統上的 unit

systemctl 提供了子命令可以查看系統上的 unit,命令格式為:
systemctl [command] [--type=type] [--all]
command 有:
list-units:列出當前已經啟動的 unit,如果添加 -all 選項會同時列出沒有啟動的 unit。
list-unit-files:根據 /lib/systemd/system/ 目錄內的文件列出所有的 unit。
--type=type:可以過濾某個類型的 unit。
不帶任何參數執行 systemctl 命令會列出所有已啟動的 unit:

linux systemctl命令詳解

系統默認啟動的服務是非常多的,上圖只截取了前面幾行。下面是對輸出的介紹:
unit:項目的名稱,包括各個 unit 的類別(看擴展名)。
load:開機時 unit 的配置是否被加載。
active:目前的狀態,須與后續的 sub 搭配!就是我們用 systemctl status 觀察時,active的內容。
description:描述信息。
注意,systemctl 不加參數,其實等同于 systemctl list-units!

下面我們查看系統上一共安裝了多少 unit:

?
1
$ sudo systemctl list-unit-files

linux systemctl命令詳解

結果也非常的多,我們仍然只截取一部分結果。這里的 state 就是我們前面介紹的 服務的啟動狀態,有 enable 和 disable、static 和 mask。

只查看某種類型的 unit

比如我們只想看服務類型的 unit:

?
1
$ systemctl list-units --type=service --all

這次只有以 .service 結尾的 unit 才會出現。

如果要看 mount 類型的 unit 指定 --type=mount 就可以了:

linux systemctl命令詳解

查看加載失敗的 unit

如果發現某個 unit 不工作,可以查看是否有 unit 加載失敗:

?
1
$ systemctl --failed

 

linux systemctl命令詳解

管理不同的操作環境(target unit)

通過指定 --type=target 就可以用 systemctl list-units 命令查看系統中默認有多少種 target:

linux systemctl命令詳解

筆者的 ubuntu 16.04 中居然有 27 個 target!我們在此僅介紹幾個常用的 target。
graphical.target:就是文字界面再加上圖形界面,這個 target 已經包含了下面的 multi-user.target。
multi-user.target:純文本模式!
rescue.target:在無法使用 root 登陸的情況下,systemd 在開機時會多加一個額外的臨時系統,與你原本的系統無關。這時你可以取得 root 的權限來維護你的系統。
emergency.target:緊急處理系統的錯誤,在無法使用 rescue.target 時,可以嘗試使用這種模式!
shutdown.target:就是執行關機。
getty.target:可以設置 tty 的配置。
正常的模式是 multi-user.target 和 graphical.target 兩個,救援方面的模式主要是 rescue.target 以及更嚴重的 emergency.target。如果要修改可提供登陸的 tty 數量,則修改 getty.target。

下面是操作 target unit 命令的格式:
systemctl [command] [unit.target]
command 有:
get-default:取得目前的 target。
set-default:設置后面接的 target 成為默認的操作模式。
isolate:切換到后面接的模式。

查看和設置默認的 target

?
1
$ sudo systemctl get-default

linux systemctl命令詳解

筆者系統的默認 target 為 graphical.target,所以啟動時默認啟動圖形界面。下面我們把它設置為 multi-user.target:

?
1
$ sudo systemctl set-default multi-user.target

linux systemctl命令詳解

實際的執行過程是刪除之前的鏈接文件,然后創建新的到 /lib/systemd/system/multi-user.target 的鏈接文件。這樣下次開機時默認會進入純文本模式。

切換 target

我們還可以在不重新啟動的情況下切換不同的 target,比如從圖形界面切換到純文本的模式:

?
1
$ sudo systemctl isolate multi-user.target

在一般情況下,使用上述 isolate 的方式即可完成不同 target 的切換。不過為了方便起見,systemd 也提供了
幾個簡單的指令用來切換操作模式,大致如下所示:

?
1
2
3
4
5
6
$ sudo systemctl poweroff  # 系統關機
$ sudo systemctl reboot    # 重新開機
$ sudo systemctl suspend   # 進入暫停模式
$ sudo systemctl hibernate  # 進入休眠模式
$ sudo systemctl rescue    # 強制進入救援模式
$ sudo systemctl emergency # 強制進入緊急救援模式

這里簡單介紹一下暫停模式與休眠模式的區別
suspend:暫停模式會將系統的狀態保存到內存中,然后關閉掉大部分的系統硬件,當然,并沒有實際關機。當用戶按下喚醒機器的按鈕,系統數據會從內存中回復,然后重新驅動被大部分關閉的硬件,所以喚醒系統的速度比較快。
hibernate:休眠模式則是將系統狀態保存到硬盤當中,保存完畢后,將計算機關機。當用戶嘗試喚醒系統時,系統會開始正常運行,然后將保存在硬盤中的系統狀態恢復回來。因為數據需要從硬盤讀取,因此喚醒的速度比較慢(如果你使用的是 ssd 磁盤,喚醒的速度也是非常快的)。

檢查 unit 之間的依賴性

很多服務之間是有依賴關系的,systemd 的一大亮點就是可以管理 unit 之間的依賴關系。我們可以通過下面的命令來查看 unit 間的依賴關系:

systemctl list-dependencies [unit] [--reverse] 選項 --reverse 會反向追蹤是誰在使用這個 unit。

下面讓我們看看當前運行的 target 的依賴關系:

linux systemctl命令詳解

我們當前運行在 graphical.target 下,它由一個長長的依賴列表(上圖并未展示所有的項目),其中最重要的依賴項目為 multi-user.target。下面我們使用 --reverse 選項查看 multi-user.target unit 被誰使用:

?
1
$ systemctl list-dependencies multi-user.target --reverse

linux systemctl命令詳解

從上面兩張圖上我們可以確定下面的關系:graphical.target 依賴 multi-user.target。
我們這里只是通過 target unit 介紹了如何查看 unit 之間的依賴關系,實際使用中更多的是檢查服務 unit 之間的依賴關系。

相關的目錄和文件

在不同的發行版中與 systemd 相關的文件路徑可能會不太一樣,強調一下,本文介紹的是 ubuntu 16.04 。
/lib/systemd/system/ 大多數 unit 的配置文件都放在這個目錄下。
/run/systemd/system/ 系統運行過程中產生的腳本,比如用戶相關的腳本和會話相關的腳本。
/etc/systemd/system/ 這個目錄中主要的文件都是指向 /lib/systemd/system/ 目錄中的鏈接文件。
注意,在我們自己創建 unit 配置文件時,既可以把配置文件放在 /lib/systemd/system/ 目錄下,也可以放在 /etc/systemd/system/ 目錄下。

/etc/default/ 這個目錄中放置很多服務默認的配置文件。
/var/lib/ 一些會產生數據的服務都會將他的數據寫入到 /var/lib/ 目錄中,比如 docker 相關的數據文件就放在這個目錄下。
/run/ 這個目錄放置了好多服務運行時的臨時數據,比如 lock file 以及 pid file 等等。

我們知道 systemd 里管理了很多會用到本機 socket 的服務,所以系統中肯定會產生很多的 socket 文件。那么,這些 socke 文件都存放在哪里呢?我們可以使用 systemctl 進行查看:

?
1
$ systemctl list-sockets

linux systemctl命令詳解

其實,絕大多數的 socket 文件都存放在 /run 目錄及其子目錄中。

systemctl daemon-reload 子命令

daemon-reload 是一個很容易被誤用的子命令,主要是因為它名字中包含的 daemon 一詞很容易讓它和 reload 子命令混淆。
我們在前文簡略的介紹了 reload 子命令,它的作用是重新加載某個服務程序的配置文件。這里的程序指的是服務類型 unit 的配置中指定的程序,也就是我們常說的 daemon(提供某種服務的應用程序)。比如服務類型的 unit prometheus.service,提供服務的 daemon 程序在我的機器上是 /usr/local/share/prometheus/prometheus,所以 reload 子命令重新加載的是 prometheus 的配置文件。

如果把 daemon-reload 子命令中的 daemon 理解為 systemd 程序,就可以把這個命令解釋為重新加載 systemd 程序的配置文件。而所有的 unit 配置文件都是作為 systemd 程序的配置文件存在的。這樣得出的結論就是:

  1. 新添加 unit 配置文件時需要執行 daemon-reload 子命令
  2. 有 unit 的配置文件發生變化時也需要執行 daemon-reload 子命令

daemon-reload 命令會做很多的事情,其中之一是重新生成依賴樹(也就是 unit 之間的依賴關系),所以當你修改了 unit 配置文件中的依賴關系后如果不執行 daemon-reload 命令是不會生效的。

如果大家想對linux命令有更加系統深入的學習,可以參閱 Linux命令速查手冊 PDF中文第三版 這本經典書籍

總結

systemctl 提供了管理 systemd 和系統服務的眾多子命令。本文只是走馬觀花的把主要的子命令和一些常見的用法介紹了一下。對于這么一個龐大的命令集和相信只有在使用中不斷的磨練才能夠真正的掌握它們。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://www.cnblogs.com/sparkdev/p/8472711.html

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 成人a视频 | 天天干狠狠操 | 成人午夜视频在线 | 亚洲h视频| 国产99在线 | 亚洲 | 成人在线日本 | 亚洲高清在线观看 | 黄片毛片毛片毛片 | 久久精品久久久 | 亚洲国产精品久久 | 日韩高清不卡一区二区三区 | 日本黄色毛片 | 亚洲成人av在线 | 亚洲人成网站b2k3cm | 九九99九九 | av观看 | 久久久精品观看 | 亚洲精品久久久久久下一站 | 欧美一级在线观看 | 亚洲视频 欧美视频 | 黄瓜av| 免费观看一区二区三区毛片软件 | 高清一区二区在线观看 | 国产精品欧美久久久久久 | 久久99精品久久久 | 亚洲成人黄色 | 99视频精品 | 国产一区二区在线免费观看 | 91精品视频导航 | 精品国产黄a∨片高清在线 黄色大片aaaa | 操久久 | 欧美一区二区三区精品 | 高清免费av | 久久九九国产精品 | 国产精品综合 | 中文字幕日韩在线 | 精品久久久av | 91av爱爱| 国产视频第一页 | 中文字幕亚洲精品 | 欧美成人a |