Linux 系统服务管理和控制程序(初始化系统/Init System) -- systemd 介绍
文章目錄
- systemd 簡介
- systemd 啟動過程概述
- Systemd的爭議
systemd 簡介
開發(fā)systemd的主要目的就是減少系統(tǒng)引導(dǎo)時間和計(jì)算開銷。systemd(系統(tǒng)管理守護(hù)進(jìn)程),最開始以GNU GPL協(xié)議授權(quán)開發(fā),現(xiàn)在已轉(zhuǎn)為使用GNU LGPL協(xié)議,它是如今討論最熱烈的引導(dǎo)和服務(wù)管理程序。如果你的Linux系統(tǒng)配置為使用systemd引導(dǎo)程序,它取替?zhèn)鹘y(tǒng)的SysV init,啟動過程將交給systemd處理。systemd的一個核心功能是它同時支持SysV init的后開機(jī)啟動腳本。
systemd引入了并行啟動的概念,它會為每個需要啟動的守護(hù)進(jìn)程建立一個套接字,這些套接字對于使用它們的進(jìn)程來說是抽象的,這樣它們可以允許不同守護(hù)進(jìn)程之間進(jìn)行交互。systemd會創(chuàng)建新進(jìn)程并為每個進(jìn)程分配一個控制組(cgroup)。處于不同控制組的進(jìn)程之間可以通過內(nèi)核來互相通信。systemd處理開機(jī)啟動進(jìn)程的方式非常漂亮,和傳統(tǒng)基于init的系統(tǒng)比起來優(yōu)化了太多。讓我們看下systemd的一些核心亮點(diǎn)。
systemd同時也清晰地處理了系統(tǒng)關(guān)機(jī)過程。它在/usr/lib/systemd/目錄下有三個腳本,分別叫systemd-halt.service,systemd-poweroff.service,systemd-reboot.service。這幾個腳本會在用戶選擇關(guān)機(jī),重啟或待機(jī)時執(zhí)行。在接收到關(guān)機(jī)事件時,systemd首先卸載所有文件系統(tǒng)并停止所有內(nèi)存交換設(shè)備,斷開存儲設(shè)備,之后停止所有剩下的進(jìn)程。
systemd 啟動過程概述
讓我們看一下Linux系統(tǒng)在使用systemd作為引導(dǎo)程序時的開機(jī)啟動過程的結(jié)構(gòu)性細(xì)節(jié)。為了簡單,我們將在下面按步驟列出來這個過程:
當(dāng)你打開電源后電腦所做的第一件事情就是BIOS初始化。BIOS會讀取引導(dǎo)設(shè)備設(shè)定,定位并傳遞系統(tǒng)控制權(quán)給MBR(假設(shè)硬盤是第一引導(dǎo)設(shè)備)。
MBR從Grub或LILO引導(dǎo)程序讀取相關(guān)信息并初始化內(nèi)核。接下來將由Grub或LILO繼續(xù)引導(dǎo)系統(tǒng)。如果你在grub配置文件里指定了systemd作為引導(dǎo)管理程序,之后的引導(dǎo)過程將由systemd完成。systemd使用“target”來處理引導(dǎo)和服務(wù)管理過程。這些systemd里的“target”文件被用于分組不同的引導(dǎo)單元以及啟動同步進(jìn)程。
systemd執(zhí)行的第一個目標(biāo)是default.target。但實(shí)際上default.target是指向graphical.target的軟鏈接。Linux里的軟鏈接用起來和Windows下的快捷方式一樣。文件Graphical.target的實(shí)際位置是/usr/lib/systemd/system/graphical.target。在下面的截圖里顯示了graphical.target文件的內(nèi)容。
"multi-user.target"會將控制權(quán)交給另一層“basic.target”。
系統(tǒng)引導(dǎo)性能分析
systemd 提供了工具用于識別和定位引導(dǎo)相關(guān)的問題或性能影響。systemd-analyze是一個內(nèi)建的命令,可以用來檢測引導(dǎo)過程。你可以找出在啟動過程中出錯的單元,然后跟蹤并改正引導(dǎo)組件的問題。在下面列出一些常用的systemd-analyze命令。
systemd-analyze time 用于顯示內(nèi)核和普通用戶空間啟動時所花的時間。
$ systemd-analyze time Startup finished in 1440ms (kernel) + 3444ms (userspace)systemd-analyze blame 會列出所有正在運(yùn)行的單元,按從初始化開始到當(dāng)前所花的時間排序,通過這種方式你就知道哪些服務(wù)在引導(dǎo)過程中要花較長時間來啟動。
$ systemd-analyze blame 2001ms mysqld.service 234ms httpd.service 191ms vmms.servicesystemd-analyze verify 顯示在所有系統(tǒng)單元中是否有語法錯誤。
systemd-analyze plot 可以用來把整個引導(dǎo)過程寫入一個SVG格式文件里。整個引導(dǎo)過程非常長不方便閱讀,所以通過這個命令我們可以把輸出寫入一個文件,之后再查看和分析。下面這個命令就是做這個。
systemd-analyze plot > boot.svgSystemd的爭議
Systemd并沒有幸運(yùn)地獲得所有人的青睞,一些專家和管理員對于它的工作方式和開發(fā)有不同意見。根據(jù)對于Systemd的批評,它不是“類Unix”方式因?yàn)樗囍鎿Q一些系統(tǒng)服務(wù)。一些專家也不喜歡使用二進(jìn)制配置文件的想法。據(jù)說編輯systemd配置非常困難而且沒有一個可用的圖形工具。
總結(jié)
以上是生活随笔為你收集整理的Linux 系统服务管理和控制程序(初始化系统/Init System) -- systemd 介绍的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 古风句式聊天82句
- 下一篇: Linux 初始化系统(系统服务管理和控