systemd第二回

一、開(kāi)機(jī)啟動(dòng)

對(duì)于那些支持 Systemd 的軟件霜浴,安裝的時(shí)候,會(huì)自動(dòng)在/usr/lib/systemd/system目錄添加一個(gè)配置文件蓝纲。

如果你想讓該軟件開(kāi)機(jī)啟動(dòng)阴孟,就執(zhí)行下面的命令(以httpd.service為例)。


$ sudo systemctl enable httpd

上面的命令相當(dāng)于在/etc/systemd/system目錄添加一個(gè)符號(hào)鏈接税迷,指向/usr/lib/systemd/system里面的httpd.service文件永丝。

這是因?yàn)殚_(kāi)機(jī)時(shí),Systemd只執(zhí)行/etc/systemd/system目錄里面的配置文件箭养。這也意味著慕嚷,如果把修改后的配置文件放在該目錄,就可以達(dá)到覆蓋原始配置的效果毕泌。

二喝检、啟動(dòng)服務(wù)

設(shè)置開(kāi)機(jī)啟動(dòng)以后,軟件并不會(huì)立即啟動(dòng)撼泛,必須等到下一次開(kāi)機(jī)挠说。如果想現(xiàn)在就運(yùn)行該軟件,那么要執(zhí)行systemctl start命令愿题。


$ sudo systemctl start httpd

執(zhí)行上面的命令以后损俭,有可能啟動(dòng)失敗蛙奖,因此要用systemctl status命令查看一下該服務(wù)的狀態(tài)。


$ sudo systemctl status httpd

httpd.service - The Apache HTTP Server
   Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled)
   Active: active (running) since 金 2014-12-05 12:18:22 JST; 7min ago
 Main PID: 4349 (httpd)
   Status: "Total requests: 1; Current requests/sec: 0; Current traffic:   0 B/sec"
   CGroup: /system.slice/httpd.service
           ├─4349 /usr/sbin/httpd -DFOREGROUND
           ├─4350 /usr/sbin/httpd -DFOREGROUND
           ├─4351 /usr/sbin/httpd -DFOREGROUND
           ├─4352 /usr/sbin/httpd -DFOREGROUND
           ├─4353 /usr/sbin/httpd -DFOREGROUND
           └─4354 /usr/sbin/httpd -DFOREGROUND

12月 05 12:18:22 localhost.localdomain systemd[1]: Starting The Apache HTTP Server...
12月 05 12:18:22 localhost.localdomain systemd[1]: Started The Apache HTTP Server.
12月 05 12:22:40 localhost.localdomain systemd[1]: Started The Apache HTTP Server.

上面的輸出結(jié)果含義如下杆兵。

  • Loaded行:配置文件的位置雁仲,是否設(shè)為開(kāi)機(jī)啟動(dòng)
  • Active行:表示正在運(yùn)行
  • Main PID行:主進(jìn)程ID
  • Status行:由應(yīng)用本身(這里是 httpd )提供的軟件當(dāng)前狀態(tài)
  • CGroup塊:應(yīng)用的所有子進(jìn)程
  • 日志塊:應(yīng)用的日志

三、停止服務(wù)

終止正在運(yùn)行的服務(wù)琐脏,需要執(zhí)行systemctl stop命令攒砖。


$ sudo systemctl stop httpd.service

有時(shí)候,該命令可能沒(méi)有響應(yīng)骆膝,服務(wù)停不下來(lái)祭衩。這時(shí)候就不得不"殺進(jìn)程"了,向正在運(yùn)行的進(jìn)程發(fā)出kill信號(hào)阅签。


$ sudo systemctl kill httpd.service

此外掐暮,重啟服務(wù)要執(zhí)行systemctl restart命令。


$ sudo systemctl restart httpd.service

四政钟、讀懂配置文件

一個(gè)服務(wù)怎么啟動(dòng)路克,完全由它的配置文件決定。下面就來(lái)看养交,配置文件有些什么內(nèi)容精算。

前面說(shuō)過(guò),配置文件主要放在/usr/lib/systemd/system目錄碎连,也可能在/etc/systemd/system目錄灰羽。找到配置文件以后,使用文本編輯器打開(kāi)即可鱼辙。

systemctl cat命令可以用來(lái)查看配置文件廉嚼,下面以sshd.service文件為例,它的作用是啟動(dòng)一個(gè) SSH 服務(wù)器倒戏,供其他用戶(hù)以 SSH 方式登錄怠噪。


$ systemctl cat 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]
EnvironmentFile=/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
Type=simple
KillMode=process
Restart=on-failure
RestartSec=42s

[Install]
WantedBy=multi-user.target

可以看到,配置文件分成幾個(gè)區(qū)塊杜跷,每個(gè)區(qū)塊包含若干條鍵值對(duì)傍念。

下面依次解釋每個(gè)區(qū)塊的內(nèi)容。

五葛闷、 [Unit] 區(qū)塊:?jiǎn)?dòng)順序與依賴(lài)關(guān)系憋槐。

Unit區(qū)塊的Description字段給出當(dāng)前服務(wù)的簡(jiǎn)單描述,Documentation字段給出文檔位置淑趾。

接下來(lái)的設(shè)置是啟動(dòng)順序和依賴(lài)關(guān)系秦陋,這個(gè)比較重要。

After字段:表示如果network.targetsshd-keygen.service需要啟動(dòng)治笨,那么sshd.service應(yīng)該在它們之后啟動(dòng)驳概。

相應(yīng)地赤嚼,還有一個(gè)Before字段,定義sshd.service應(yīng)該在哪些服務(wù)之前啟動(dòng)顺又。

注意更卒,AfterBefore字段只涉及啟動(dòng)順序,不涉及依賴(lài)關(guān)系稚照。

舉例來(lái)說(shuō)蹂空,某 Web 應(yīng)用需要 postgresql 數(shù)據(jù)庫(kù)儲(chǔ)存數(shù)據(jù)。在配置文件中果录,它只定義要在 postgresql 之后啟動(dòng)上枕,而沒(méi)有定義依賴(lài) postgresql 。上線(xiàn)后弱恒,由于某種原因辨萍,postgresql 需要重新啟動(dòng),在停止服務(wù)期間返弹,該 Web 應(yīng)用就會(huì)無(wú)法建立數(shù)據(jù)庫(kù)連接锈玉。

設(shè)置依賴(lài)關(guān)系,需要使用Wants字段和Requires字段义起。

Wants字段:表示sshd.servicesshd-keygen.service之間存在"弱依賴(lài)"關(guān)系拉背,即如果"sshd-keygen.service"啟動(dòng)失敗或停止運(yùn)行,不影響sshd.service繼續(xù)執(zhí)行默终。

Requires字段則表示"強(qiáng)依賴(lài)"關(guān)系椅棺,即如果該服務(wù)啟動(dòng)失敗或異常退出,那么sshd.service也必須退出齐蔽。

注意土陪,Wants字段與Requires字段只涉及依賴(lài)關(guān)系,與啟動(dòng)順序無(wú)關(guān)肴熏,默認(rèn)情況下是同時(shí)啟動(dòng)的。

六顷窒、[Service] 區(qū)塊:?jiǎn)?dòng)行為

Service區(qū)塊定義如何啟動(dòng)當(dāng)前服務(wù)蛙吏。

6.1 啟動(dòng)命令

許多軟件都有自己的環(huán)境參數(shù)文件,該文件可以用EnvironmentFile字段讀取鞋吉。

EnvironmentFile字段:指定當(dāng)前服務(wù)的環(huán)境參數(shù)文件鸦做。該文件內(nèi)部的key=value鍵值對(duì),可以用$key的形式谓着,在當(dāng)前配置文件中獲取泼诱。

上面的例子中,sshd 的環(huán)境參數(shù)文件是/etc/sysconfig/sshd赊锚。

配置文件里面最重要的字段是ExecStart治筒。

ExecStart字段:定義啟動(dòng)進(jìn)程時(shí)執(zhí)行的命令屉栓。

上面的例子中,啟動(dòng)sshd耸袜,執(zhí)行的命令是/usr/sbin/sshd -D $OPTIONS友多,其中的變量$OPTIONS就來(lái)自EnvironmentFile字段指定的環(huán)境參數(shù)文件。

與之作用相似的堤框,還有如下這些字段域滥。

  • ExecReload字段:重啟服務(wù)時(shí)執(zhí)行的命令
  • ExecStop字段:停止服務(wù)時(shí)執(zhí)行的命令
  • ExecStartPre字段:?jiǎn)?dòng)服務(wù)之前執(zhí)行的命令
  • ExecStartPost字段:?jiǎn)?dòng)服務(wù)之后執(zhí)行的命令
  • ExecStopPost字段:停止服務(wù)之后執(zhí)行的命令

請(qǐng)看下面的例子。


[Service]
ExecStart=/bin/echo execstart1
ExecStart=
ExecStart=/bin/echo execstart2
ExecStartPost=/bin/echo post1
ExecStartPost=/bin/echo post2

上面這個(gè)配置文件蜈抓,第二行ExecStart設(shè)為空值启绰,等于取消了第一行的設(shè)置,運(yùn)行結(jié)果如下沟使。


execstart2
post1
post2

所有的啟動(dòng)設(shè)置之前委可,都可以加上一個(gè)連詞號(hào)(-),表示"抑制錯(cuò)誤"格带,即發(fā)生錯(cuò)誤的時(shí)候撤缴,不影響其他命令的執(zhí)行。比如叽唱,EnvironmentFile=-/etc/sysconfig/sshd(注意等號(hào)后面的那個(gè)連詞號(hào))屈呕,就表示即使/etc/sysconfig/sshd文件不存在,也不會(huì)拋出錯(cuò)誤棺亭。

6.2 啟動(dòng)類(lèi)型

Type字段定義啟動(dòng)類(lèi)型虎眨。它可以設(shè)置的值如下。

  • simple(默認(rèn)值):ExecStart字段啟動(dòng)的進(jìn)程為主進(jìn)程
  • forking:ExecStart字段將以fork()方式啟動(dòng)镶摘,此時(shí)父進(jìn)程將會(huì)退出嗽桩,子進(jìn)程將成為主進(jìn)程
  • oneshot:類(lèi)似于simple,但只執(zhí)行一次凄敢,Systemd 會(huì)等它執(zhí)行完碌冶,才啟動(dòng)其他服務(wù)
  • dbus:類(lèi)似于simple,但會(huì)等待 D-Bus 信號(hào)后啟動(dòng)
  • notify:類(lèi)似于simple涝缝,啟動(dòng)結(jié)束后會(huì)發(fā)出通知信號(hào)扑庞,然后 Systemd 再啟動(dòng)其他服務(wù)
  • idle:類(lèi)似于simple,但是要等到其他任務(wù)都執(zhí)行完拒逮,才會(huì)啟動(dòng)該服務(wù)罐氨。一種使用場(chǎng)合是為讓該服務(wù)的輸出,不與其他服務(wù)的輸出相混合

下面是一個(gè)oneshot的例子滩援,筆記本電腦啟動(dòng)時(shí)栅隐,要把觸摸板關(guān)掉,配置文件可以這樣寫(xiě)。


[Unit]
Description=Switch-off Touchpad

[Service]
Type=oneshot
ExecStart=/usr/bin/touchpad-off

[Install]
WantedBy=multi-user.target

上面的配置文件租悄,啟動(dòng)類(lèi)型設(shè)為oneshot谨究,就表明這個(gè)服務(wù)只要運(yùn)行一次就夠了,不需要長(zhǎng)期運(yùn)行恰矩。

如果關(guān)閉以后记盒,將來(lái)某個(gè)時(shí)候還想打開(kāi),配置文件修改如下外傅。


[Unit]
Description=Switch-off Touchpad

[Service]
Type=oneshot
ExecStart=/usr/bin/touchpad-off start
ExecStop=/usr/bin/touchpad-off stop
RemainAfterExit=yes

[Install]
WantedBy=multi-user.target

上面配置文件中纪吮,RemainAfterExit字段設(shè)為yes,表示進(jìn)程退出以后萎胰,服務(wù)仍然保持執(zhí)行碾盟。這樣的話(huà),一旦使用systemctl stop命令停止服務(wù)技竟,ExecStop指定的命令就會(huì)執(zhí)行冰肴,從而重新開(kāi)啟觸摸板。

6.3 重啟行為

Service區(qū)塊有一些字段榔组,定義了重啟行為熙尉。

KillMode字段:定義 Systemd 如何停止 sshd 服務(wù)。

上面這個(gè)例子中搓扯,將KillMode設(shè)為process检痰,表示只停止主進(jìn)程,不停止任何sshd 子進(jìn)程锨推,即子進(jìn)程打開(kāi)的 SSH session 仍然保持連接铅歼。這個(gè)設(shè)置不太常見(jiàn),但對(duì) sshd 很重要换可,否則你停止服務(wù)的時(shí)候椎椰,會(huì)連自己打開(kāi)的 SSH session 一起殺掉。

KillMode字段可以設(shè)置的值如下沾鳄。

  • control-group(默認(rèn)值):當(dāng)前控制組里面的所有子進(jìn)程慨飘,都會(huì)被殺掉
  • process:只殺主進(jìn)程
  • mixed:主進(jìn)程將收到 SIGTERM 信號(hào),子進(jìn)程收到 SIGKILL 信號(hào)
  • none:沒(méi)有進(jìn)程會(huì)被殺掉译荞,只是執(zhí)行服務(wù)的 stop 命令瓤的。

接下來(lái)是Restart字段。

Restart字段:定義了 sshd 退出后磁椒,Systemd 的重啟方式。

上面的例子中玫芦,Restart設(shè)為on-failure,表示任何意外的失敗,就將重啟sshd潮太。如果 sshd 正常停止(比如執(zhí)行systemctl stop命令),它就不會(huì)重啟慎皱。

Restart字段可以設(shè)置的值如下。

  • no(默認(rèn)值):退出后不會(huì)重啟
  • on-success:只有正常退出時(shí)(退出狀態(tài)碼為0)叶骨,才會(huì)重啟
  • on-failure:非正常退出時(shí)(退出狀態(tài)碼非0)茫多,包括被信號(hào)終止和超時(shí),才會(huì)重啟
  • on-abnormal:只有被信號(hào)終止和超時(shí)忽刽,才會(huì)重啟
  • on-abort:只有在收到?jīng)]有捕捉到的信號(hào)終止時(shí)天揖,才會(huì)重啟
  • on-watchdog:超時(shí)退出,才會(huì)重啟
  • always:不管是什么退出原因跪帝,總是重啟

對(duì)于守護(hù)進(jìn)程今膊,推薦設(shè)為on-failure。對(duì)于那些允許發(fā)生錯(cuò)誤退出的服務(wù)伞剑,可以設(shè)為on-abnormal斑唬。

最后是RestartSec字段。

RestartSec字段:表示 Systemd 重啟服務(wù)之前黎泣,需要等待的秒數(shù)恕刘。上面的例子設(shè)為等待42秒。

七抒倚、[Install] 區(qū)塊

Install區(qū)塊褐着,定義如何安裝這個(gè)配置文件,即怎樣做到開(kāi)機(jī)啟動(dòng)衡便。

WantedBy字段:表示該服務(wù)所在的 Target献起。

Target的含義是服務(wù)組,表示一組服務(wù)镣陕。WantedBy=multi-user.target指的是谴餐,sshd 所在的 Target 是multi-user.target

這個(gè)設(shè)置非常重要呆抑,因?yàn)閳?zhí)行systemctl enable sshd.service命令時(shí)岂嗓,sshd.service的一個(gè)符號(hào)鏈接,就會(huì)放在/etc/systemd/system目錄下面的multi-user.target.wants子目錄之中鹊碍。

Systemd 有默認(rèn)的啟動(dòng) Target厌殉。


$ systemctl get-default
multi-user.target

上面的結(jié)果表示,默認(rèn)的啟動(dòng) Target 是multi-user.target侈咕。在這個(gè)組里的所有服務(wù)公罕,都將開(kāi)機(jī)啟動(dòng)。這就是為什么systemctl enable命令能設(shè)置開(kāi)機(jī)啟動(dòng)的原因耀销。

使用 Target 的時(shí)候楼眷,systemctl list-dependencies命令和systemctl isolate命令也很有用。


# 查看 multi-user.target 包含的所有服務(wù)
$ systemctl list-dependencies multi-user.target

# 切換到另一個(gè) target
# shutdown.target 就是關(guān)機(jī)狀態(tài)
$ sudo systemctl isolate shutdown.target

一般來(lái)說(shuō),常用的 Target 有兩個(gè):一個(gè)是multi-user.target罐柳,表示多用戶(hù)命令行狀態(tài)掌腰;另一個(gè)是graphical.target,表示圖形用戶(hù)狀態(tài)张吉,它依賴(lài)于multi-user.target齿梁。官方文檔有一張非常清晰的 Target 依賴(lài)關(guān)系圖

八肮蛹、Target 的配置文件

Target 也有自己的配置文件勺择。


$ systemctl cat multi-user.target

[Unit]
Description=Multi-User System
Documentation=man:systemd.special(7)
Requires=basic.target
Conflicts=rescue.service rescue.target
After=basic.target rescue.service rescue.target
AllowIsolate=yes

注意,Target 配置文件里面沒(méi)有啟動(dòng)命令蔗崎。

上面輸出結(jié)果中酵幕,主要字段含義如下。

Requires字段:要求basic.target一起運(yùn)行缓苛。

Conflicts字段:沖突字段芳撒。如果rescue.servicerescue.target正在運(yùn)行,multi-user.target就不能運(yùn)行未桥,反之亦然笔刹。

After:表示multi-user.targetbasic.targetrescue.service冬耿、 rescue.target之后啟動(dòng)舌菜,如果它們有啟動(dòng)的話(huà)。

AllowIsolate:允許使用systemctl isolate命令切換到multi-user.target亦镶。

九日月、修改配置文件后重啟

修改配置文件以后,需要重新加載配置文件缤骨,然后重新啟動(dòng)相關(guān)服務(wù)爱咬。


# 重新加載配置文件
$ sudo systemctl daemon-reload

# 重啟相關(guān)服務(wù)
$ sudo systemctl restart foobar

(完)

參考文獻(xiàn):
轉(zhuǎn)自
http://www.ruanyifeng.com/blog/2016/03/systemd-tutorial-part-two.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市绊起,隨后出現(xiàn)的幾起案子精拟,更是在濱河造成了極大的恐慌,老刑警劉巖虱歪,帶你破解...
    沈念sama閱讀 218,284評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蜂绎,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡笋鄙,警方通過(guò)查閱死者的電腦和手機(jī)师枣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)萧落,“玉大人践美,你說(shuō)我怎么就攤上這事劳殖。” “怎么了拨脉?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,614評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)宣增。 經(jīng)常有香客問(wèn)我玫膀,道長(zhǎng),這世上最難降的妖魔是什么爹脾? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,671評(píng)論 1 293
  • 正文 為了忘掉前任帖旨,我火速辦了婚禮,結(jié)果婚禮上灵妨,老公的妹妹穿的比我還像新娘解阅。我一直安慰自己,他們只是感情好泌霍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布货抄。 她就那樣靜靜地躺著,像睡著了一般朱转。 火紅的嫁衣襯著肌膚如雪蟹地。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,562評(píng)論 1 305
  • 那天藤为,我揣著相機(jī)與錄音怪与,去河邊找鬼。 笑死缅疟,一個(gè)胖子當(dāng)著我的面吹牛分别,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播存淫,決...
    沈念sama閱讀 40,309評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼耘斩,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了纫雁?” 一聲冷哼從身側(cè)響起煌往,我...
    開(kāi)封第一講書(shū)人閱讀 39,223評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎轧邪,沒(méi)想到半個(gè)月后刽脖,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡忌愚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評(píng)論 3 336
  • 正文 我和宋清朗相戀三年曲管,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片硕糊。...
    茶點(diǎn)故事閱讀 39,981評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡院水,死狀恐怖腊徙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情檬某,我是刑警寧澤撬腾,帶...
    沈念sama閱讀 35,705評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站恢恼,受9級(jí)特大地震影響民傻,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜场斑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評(píng)論 3 330
  • 文/蒙蒙 一漓踢、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧漏隐,春花似錦喧半、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,904評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至脖隶,卻和暖如春吴菠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背浩村。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,023評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工做葵, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人心墅。 一個(gè)月前我還...
    沈念sama閱讀 48,146評(píng)論 3 370
  • 正文 我出身青樓酿矢,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親怎燥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瘫筐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容