主頁 > 知識庫 > 在Debian上使用systemd工具對系統(tǒng)進(jìn)行管理的方法

在Debian上使用systemd工具對系統(tǒng)進(jìn)行管理的方法

熱門標(biāo)簽:長沙智能外呼電銷機(jī)器人供應(yīng)商 外呼系統(tǒng)架構(gòu)流程 直銷培訓(xùn)電銷機(jī)器人哪家便宜 宣威地圖標(biāo)注app 銀川外呼系統(tǒng)一般多少錢 廣州400電話辦理推選易號網(wǎng) 北京點(diǎn)撥外呼系統(tǒng)好用嗎 ?? 最近外呼系統(tǒng)被封號

“一個(gè)軟件只做一件事情”的哲學(xué)思想已經(jīng)被這個(gè)新來者徹底顛覆。除了取代了 sysvinit 成為新的系統(tǒng)初始化工具外,systemd 還是一個(gè)系統(tǒng)管理工具。目前為止,由于 systemd-sysv 這個(gè)軟件包提供的兼容性,那些我們使用慣了的工具還能繼續(xù)工作。但是當(dāng) Debian 將 systemd 升級到214版本后,這種兼容性就不復(fù)存在了。升級措施預(yù)計(jì)會(huì)在 Debian 8 "Jessie" 的穩(wěn)定分支上進(jìn)行。從此以后用戶必須使用新的命令來管理系統(tǒng)、執(zhí)行任務(wù)、變換運(yùn)行級別、查詢系統(tǒng)日志等等。不過這里有一個(gè)應(yīng)對方案,那就是在 .bashrc 文件里面添加一些別名。

現(xiàn)在就讓我們來看看 systemd 是怎么改變你管理系統(tǒng)的習(xí)慣的。在使用 systemd 之前,你得先把 sysvinit 保存起來,以便在 systemd 出錯(cuò)的時(shí)候還能用 sysvinit 啟動(dòng)系統(tǒng)。這種方法只有在沒安裝 systemd-sysv 的情況下才能生效,具體操作方法如下:

   

復(fù)制代碼
代碼如下:
# cp -av /sbin/init /sbin/init.sysvinit

在緊急情況下,可以把下面的文本:

   

復(fù)制代碼
代碼如下:
init=/sbin/init.sysvinit

添加到內(nèi)核啟動(dòng)參數(shù)項(xiàng)那里。
systemctl 的基本用法

systemctl 的功能是替代“/etc/init.d/foo start/stop”這類命令,另外,其實(shí)它還能做其他的事情,這點(diǎn)你可以參考 man 文檔。

一些基本用法:

    systemctl - 列出所有單元(UNIT)以及它們的狀態(tài)(這里的 UNIT 指的就是系統(tǒng)上的 job 和 service)
    systemctl list-units - 列出所有 UNIT
    systemctl start [NAME...] - 啟動(dòng)一項(xiàng)或多項(xiàng) UNIT
    systemctl stop [NAME...] - 停止一項(xiàng)或多項(xiàng) UNIT
    systemctl disable [NAME...] - 將 UNIT 設(shè)置為開機(jī)不啟動(dòng)
    systemctl list-unit-files - 列出所有已安裝的 UNIT,以及它們的狀態(tài)
    systemctl --failed - 列出開機(jī)啟動(dòng)失敗的 UNIT
    systemctl --type=mount - 列出某種類型的 UNIT,類型包含:service, mount, device, socket, target
    systemctl enable debug-shell.service - 將一個(gè) shell 腳本設(shè)置為開機(jī)啟動(dòng),用于調(diào)試

為了更方便處理這些 UNIT,你可以使用 systemd-ui 軟件包,你只要輸入 systemadm 命令就可以使用這個(gè)軟件。

你同樣可以使用 systemctl 實(shí)現(xiàn)轉(zhuǎn)換運(yùn)行級別、重啟系統(tǒng)和關(guān)閉系統(tǒng)的功能:

    systemctl isolate graphical.target - 切換到運(yùn)行級別5,就是有桌面的運(yùn)行級別
    systemctl isolate multi-user.target - 切換到運(yùn)行級別3,沒有桌面的運(yùn)行級別
    systemctl reboot - 重啟系統(tǒng)
    systemctl poweroff - 關(guān)機(jī)

所有命令,包括切換到其他運(yùn)行級別的命令,都可以在普通用戶的權(quán)限下執(zhí)行。
journalctl 的基本用法

systemd 不僅提供了比 sysvinit 更快的啟動(dòng)速度,還讓日志系統(tǒng)在更早的時(shí)候啟動(dòng)起來,可以記錄內(nèi)核初始化階段、內(nèi)存初始化階段、前期啟動(dòng)步驟以及主要的系統(tǒng)執(zhí)行過程的日志。所以,以前那種需要通過對顯示屏拍照或者暫停系統(tǒng)來調(diào)試程序的日子已經(jīng)一去不復(fù)返啦。

systemd 的日志文件都被放在 /var/log 目錄。如果你想使用它的日志功能,需要執(zhí)行一些命令,因?yàn)?Debian 沒有打開日志功能。命令如下:

   

復(fù)制代碼
代碼如下:
# addgroup --system systemd-journal
# mkdir -p /var/log/journal
# chown root:systemd-journal /var/log/journal
# gpasswd -a $user systemd-journal

通過上面的設(shè)置,你就可以以普通用戶權(quán)限使用 journal 軟件查看日志。使用 journalctl 查詢?nèi)罩究梢垣@得一些比 syslog 軟件更方便的玩法:

    journalctl --all - 顯示系統(tǒng)上所有日志,以及它的用戶
    journalctl -f - 監(jiān)視系統(tǒng)日志的變化(類似 tail -f /var/log/messages 的效果)
    journalctl -b - 顯示系統(tǒng)啟動(dòng)以后的日志
    journalctl -k -b -1 - 顯示上一次(-b -1)系統(tǒng)啟動(dòng)前產(chǎn)生的內(nèi)核日志
    journalctl -b -p err - 顯示系統(tǒng)啟動(dòng)后產(chǎn)生的“ERROR”日志
    journalctl --since=yesterday - 當(dāng)系統(tǒng)不會(huì)經(jīng)常重啟的時(shí)候,這條命令能提供比 -b 更短的日志記錄
    journalctl -u cron.service --since='2014-07-06 07:00' --until='2014-07-06 08:23' - 顯示 cron 服務(wù)在某個(gè)時(shí)間段內(nèi)打印出來的日志
    journalctl -p 2 --since=today - 顯示優(yōu)先級別為2以內(nèi)的日志,包含 emerg、alert、crit三個(gè)級別。所有日志級別有: emerg (0), alert (1), crit (2), err (3), warning (4), notice (5), info (6), debug (7)
    journalctl > yourlog.log - 將二進(jìn)制日志文件復(fù)制成文本文件并保存到當(dāng)前目錄

Journal 和 syslog 可以很好的共存。而另一方面,一旦你習(xí)慣了操作 journal,你也可以卸載掉所有 syslog 的軟件,比如 rsyslog 或 syslog-ng。

如果想要得到更詳細(xì)的日志信息,你可以在內(nèi)核啟動(dòng)參數(shù)上添加“systemd.log_level=debug”,然后運(yùn)行下面的命令:

   

復(fù)制代碼
代碼如下:
# journalctl -alb

你也可以編輯 /etc/systemd/system.conf 文件來修改日志級別。
利用 systemd 分析系統(tǒng)啟動(dòng)過程

systemd 可以讓你能更有效地分析和優(yōu)化你的系統(tǒng)啟動(dòng)過程:

    systemd-analyze - 顯示本次啟動(dòng)系統(tǒng)過程中用戶態(tài)和內(nèi)核態(tài)所花的時(shí)間
    systemd-analyze blame - 顯示每個(gè)啟動(dòng)項(xiàng)所花費(fèi)的時(shí)間明細(xì)
    systemd-analyze critical-chain - 按時(shí)間順序打印 UNIT 樹
    systemd-analyze dot | dot -Tsvg > systemd.svg - 為開機(jī)啟動(dòng)過程生成向量圖(需要安裝 graphviz 軟件包)
    systemd-analyze plot > bootplot.svg - 產(chǎn)生開機(jī)啟動(dòng)過程的時(shí)間圖表

systemd 雖然是個(gè)年輕的項(xiàng)目,但已有大量文檔。首先要介紹給你的是Lennart Poettering 的 0pointer 系列。這個(gè)系列非常詳細(xì),非常有技術(shù)含量。另外一個(gè)是免費(fèi)桌面信息文檔,它包含了最詳細(xì)的關(guān)于 systemd 的鏈接:發(fā)行版特性文件、bug 跟蹤系統(tǒng)和說明文檔。你可以使用下面的命令來查詢 systemd 都提供了哪些文檔:

   

復(fù)制代碼
代碼如下:
# man systemd.index

不同發(fā)行版之間的 systemd 提供的命令基本一樣,最大的不同之處就是打包方式。

標(biāo)簽:呼和浩特 濟(jì)寧 揭陽 邵陽 吐魯番 保山 濰坊 梅州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在Debian上使用systemd工具對系統(tǒng)進(jìn)行管理的方法》,本文關(guān)鍵詞  在,Debian,上,使用,systemd,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在Debian上使用systemd工具對系統(tǒng)進(jìn)行管理的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于在Debian上使用systemd工具對系統(tǒng)進(jìn)行管理的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章