一灭袁、開機(jī)啟動(dòng)
對(duì)于那些支持 Systemd 的軟件猬错,安裝的時(shí)候,會(huì)自動(dòng)在/usr/lib/systemd/system目錄添加一個(gè)配置文件茸歧。
如果你想讓該軟件開機(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)殚_機(jī)時(shí),Systemd只執(zhí)行/etc/systemd/system目錄里面的配置文件涤浇。這也意味著鳖藕,如果把修改后的配置文件放在該目錄,就可以達(dá)到覆蓋原始配置的效果只锭。
二著恩、啟動(dòng)服務(wù)
設(shè)置開機(jī)啟動(dòng)以后,軟件并不會(huì)立即啟動(dòng),必須等到下一次開機(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è)為開機(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í)候,該命令可能沒有響應(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目錄照捡。找到配置文件以后,使用文本編輯器打開即可话侧。
systemctl cat命令可以用來(lái)查看配置文件栗精,下面以sshd.service文件為例,它的作用是啟動(dòng)一個(gè) SSH 服務(wù)器瞻鹏,供其他用戶以 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)順序與依賴關(guān)系。
Unit區(qū)塊的Description字段給出當(dāng)前服務(wù)的簡(jiǎn)單描述,Documentation字段給出文檔位置涩蜘。
接下來(lái)的設(shè)置是啟動(dòng)順序和依賴關(guān)系嚼贡,這個(gè)比較重要。
After字段:表示如果network.target或sshd-keygen.service需要啟動(dòng)同诫,那么sshd.service應(yīng)該在它們之后啟動(dòng)粤策。
相應(yīng)地,還有一個(gè)Before字段误窖,定義sshd.service應(yīng)該在哪些服務(wù)之前啟動(dòng)叮盘。
注意,After和Before字段只涉及啟動(dòng)順序霹俺,不涉及依賴關(guān)系柔吼。
舉例來(lái)說(shuō),某 Web 應(yīng)用需要 postgresql 數(shù)據(jù)庫(kù)儲(chǔ)存數(shù)據(jù)丙唧。在配置文件中愈魏,它只定義要在 postgresql 之后啟動(dòng),而沒有定義依賴 postgresql 想际。上線后培漏,由于某種原因,postgresql 需要重新啟動(dòng)胡本,在停止服務(wù)期間牌柄,該 Web 應(yīng)用就會(huì)無(wú)法建立數(shù)據(jù)庫(kù)連接。
設(shè)置依賴關(guān)系打瘪,需要使用Wants字段和Requires字段友鼻。
Wants字段:表示sshd.service與sshd-keygen.service之間存在"弱依賴"關(guān)系,即如果"sshd-keygen.service"啟動(dòng)失敗或停止運(yùn)行闺骚,不影響sshd.service繼續(xù)執(zhí)行彩扔。
Requires字段則表示"強(qiáng)依賴"關(guān)系,即如果該服務(wù)啟動(dòng)失敗或異常退出僻爽,那么sshd.service也必須退出虫碉。
注意,Wants字段與Requires字段只涉及依賴關(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)類型
Type字段定義啟動(dòng)類型菇曲。它可以設(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:類似于simple弟胀,但只執(zhí)行一次,Systemd 會(huì)等它執(zhí)行完喊式,才啟動(dòng)其他服務(wù)
dbus:類似于simple孵户,但會(huì)等待 D-Bus 信號(hào)后啟動(dòng)
notify:類似于simple,啟動(dòng)結(jié)束后會(huì)發(fā)出通知信號(hào)岔留,然后 Systemd 再啟動(dòng)其他服務(wù)
idle:類似于simple夏哭,但是要等到其他任務(wù)都執(zhí)行完,才會(huì)啟動(dòng)該服務(wù)献联。一種使用場(chǎng)合是為讓該服務(wù)的輸出方庭,不與其他服務(wù)的輸出相混合
下面是一個(gè)oneshot的例子厕吉,筆記本電腦啟動(dòng)時(shí),要把觸摸板關(guān)掉械念,配置文件可以這樣寫。
[Unit]
Description=Switch-off Touchpad
[Service]
Type=oneshot
ExecStart=/usr/bin/touchpad-off
[Install]
WantedBy=multi-user.target
上面的配置文件运悲,啟動(dòng)類型設(shè)為oneshot龄减,就表明這個(gè)服務(wù)只要運(yùn)行一次就夠了,不需要長(zhǎng)期運(yùn)行班眯。
如果關(guān)閉以后希停,將來(lái)某個(gè)時(shí)候還想打開,配置文件修改如下署隘。
[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í)行违崇。這樣的話,一旦使用systemctl stop命令停止服務(wù)诊霹,ExecStop指定的命令就會(huì)執(zhí)行羞延,從而重新開啟觸摸板。
6.3 重啟行為
Service區(qū)塊有一些字段脾还,定義了重啟行為伴箩。
KillMode字段:定義 Systemd 如何停止 sshd 服務(wù)。
上面這個(gè)例子中鄙漏,將KillMode設(shè)為process嗤谚,表示只停止主進(jìn)程,不停止任何sshd 子進(jìn)程怔蚌,即子進(jìn)程打開的 SSH session 仍然保持連接巩步。這個(gè)設(shè)置不太常見,但對(duì) sshd 很重要媚创,否則你停止服務(wù)的時(shí)候渗钉,會(huì)連自己打開的 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:沒有進(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è)配置文件损合,即怎樣做到開機(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ù)了牛,都將開機(jī)啟動(dòng)颜屠。這就是為什么systemctl enable命令能設(shè)置開機(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,表示多用戶命令行狀態(tài)粗井;另一個(gè)是graphical.target肴掷,表示圖形用戶狀態(tài),它依賴于multi-user.target背传。官方文檔有一張非常清晰的 Target 依賴關(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 配置文件里面沒有啟動(dòng)命令颤介。
上面輸出結(jié)果中梳星,主要字段含義如下。
Requires字段:要求basic.target一起運(yùn)行滚朵。
Conflicts字段:沖突字段冤灾。如果rescue.service或rescue.target正在運(yùn)行,multi-user.target就不能運(yùn)行辕近,反之亦然韵吨。
After:表示multi-user.target在basic.target 、 rescue.service移宅、 rescue.target之后啟動(dòng)归粉,如果它們有啟動(dòng)的話。
AllowIsolate:允許使用systemctl isolate命令切換到multi-user.target漏峰。
九糠悼、修改配置文件后重啟
修改配置文件以后,需要重新加載配置文件浅乔,然后重新啟動(dòng)相關(guān)服務(wù)倔喂。
# 重新加載配置文件
$ sudo systemctl daemon-reload
# 重啟相關(guān)服務(wù)
$ sudo systemctl restart foobar