systemd是靠管理unit的方式來控制開機服務,開機級別等功能。
在/lib/systemd/system目錄下包含了各種unit檔案,有service字尾的服務unit,有target字尾的開機級別unit等,這裡介紹關於service字尾的檔案。因為systemd在開機要想執行自啟動,都是通過這些*.service 的unit控制的,服務又分為系統服務(system)和使用者服務(user)。
系統服務:開機不登陸就能執行的程式(常用於開機自啟)。
使用者服務:需要登陸以後才能執行的程式。
二、配置檔案說明:
[unit] 區塊:啟動順序與依賴關係
description欄位:給出當前服務的簡單描述。
documentation欄位:給出文件位置。
after欄位:如果network.target或sshd-keygen.service需要啟動,那麼sshd.service應該在它們之後啟動。
before欄位:定義sshd.service應該在哪些服務之前啟動。
注:after和before欄位只涉及啟動順序,不涉及依賴關係。
舉例來說,某 web 應用需要 postgresql 資料庫儲存資料。在配置檔案中,它只定義要在 postgresql 之後啟動,而沒有定義依賴 postgresql 。上線後,由於某種原因,postgresql 需要重新啟動,在停止服務期間,該 web 應用就會無法建立資料庫連線。
設定依賴關係,需要使用wants欄位和requires欄位。
wants欄位:表示sshd.service與sshd-keygen.service之間存在"弱依賴"關係,即如果"sshd-keygen.service"啟動失敗或停止執行,不影響sshd.service繼續執行。
requires欄位則表示"強依賴"關係,即如果該服務啟動失敗或異常退出,那麼sshd.service也必須退出。
注意,wants欄位與requires欄位只涉及依賴關係,與啟動順序無關,預設情況下是同時啟動的。
[service] 區塊:啟動行為
啟動命令
execstart欄位:定義啟動程序時執行的命令
execreload欄位:重啟服務時執行的命令
execstop欄位:停止服務時執行的命令
execstartpre欄位:啟動服務之前執行的命令
execstartpost欄位:啟動服務之後執行的命令
execstoppost欄位:停止服務之後執行的命令
注:所有的啟動設定之前,都可以加上乙個連詞號(-),表示"抑制錯誤",即發生錯誤的時候,不影響其他命令的執行。比如environmentfile=-/etc/sysconfig/sshd(注意等號後面的那個連詞號),就表示即使/etc/sysconfig/sshd檔案不存在,也不會丟擲錯誤。
注意:[service]中的啟動、重啟、停止命令全部要求使用絕對路徑!
啟動型別
type欄位定義啟動型別。它可以設定的值如下:
******(預設值):execstart欄位啟動的程序為主程序
forking:execstart欄位將以fork()方式啟動,此時父程序將會退出,子程序將成為主程序(後台執行)
oneshot:類似於******,但只執行一次,systemd 會等它執行完,才啟動其他服務
dbus:類似於******,但會等待 d-bus 訊號後啟動
notify:類似於******,啟動結束後會發出通知訊號,然後 systemd 再啟動其他服務
idle:類似於******,但是要等到其他任務都執行完,才會啟動該服務。一種使用場合是為讓該服務的輸出,不與其他服務的輸出相混合
重啟行為
service區塊有一些字段,定義了重啟行為:
killmode欄位:定義 systemd 如何停止 sshd 服務:
control-group(預設值):當前控制組裡面的所有子程序,都會被殺掉
process:只殺主程序
mixed:主程序將收到 sigterm 訊號,子程序收到 sigkill 訊號
none:沒有程序會被殺掉,只是執行服務的 stop 命令。
restart欄位:定義了 sshd 退出後,systemd 的重啟方式
上面的例子中,restart設為on-failure,表示任何意外的失敗,就將重啟sshd。如果 sshd 正常停止(比如執行systemctl stop命令),它就不會重啟。
restart欄位可以設定的值如下。
no(預設值):退出後不會重啟
on-success:只有正常退出時(退出狀態碼為0),才會重啟
on-failure:非正常退出時(退出狀態碼非0),包括被訊號終止和超時,才會重啟
on-abnormal:只有被訊號終止和超時,才會重啟
on-abort:只有在收到沒有捕捉到的訊號終止時,才會重啟
on-watchdog:超時退出,才會重啟
always:不管是什麼退出原因,總是重啟
restartsec欄位:表示 systemd 重啟服務之前,需要等待的秒數。
上面的例子設為等待42秒。
[install] 區塊
install區塊,定義如何安裝這個配置檔案,即怎樣做到開機啟動。
wantedby欄位:表示該服務所在的 target。
target的含義是服務組,表示一組服務。
wantedby=multi-user.target指的是:sshd 所在的 target 是multi-user.target。
這個設定非常重要,因為執行systemctl enable sshd.service命令時,sshd.service的乙個符號鏈結,就會放在/etc/systemd/system目錄下面的multi-user.target.wants子目錄之中。
systemd 有預設的啟動 target。
systemctl get-default
#輸出multi-user.target
上面的結果表示,預設的啟動 target 是multi-user.target。在這個組裡的所有服務,都將開機啟動。這就是為什麼systemctl enable命令能設定開機啟動的原因。
使用 target 的時候,systemctl list-dependencies命令和systemctl isolate命令也很有用。
複製**
#檢視 multi-user.target 包含的所有服務
systemctl list-dependencies multi-user.target
#切換到另乙個 target
#shutdown.target 就是關機狀態
systemctl isolate shutdown.target
複製**
一般來說,常用的 target 有兩個:
multi-user.target:表示多使用者命令列狀態;
graphical.target:表示圖形使用者狀態,它依賴於multi-user.target。
三、註冊服務例項
配置檔案目錄
systemctl指令碼目錄:/usr/lib/systemd/
系統服務目錄:/usr/lib/systemd/system/
使用者服務目錄:/usr/lib/systemd/system/
在/usr/lib/systemd/system目錄下新建service-name.service檔案:
[unit]
#服務描述
description=media wanager service
#指定了在systemd在執行完那些target之後再啟動該服務
after=network.target
[service]
#定義service的執行型別,一般是forking(後台執行)
type=forking
#定義systemctl start|stop|reload *.service 的執行方法(具體命令需要寫絕對路徑)
#注:execstartpre為啟動前執行的命令
execstartpre=/usr/bin/test 「x$」 = xyes
execreload=
#建立私有的記憶體臨時空間
privatetmp=true
[install]
#多使用者
wantedby=multi-user.target
過載系統服務:systemctl daemon-reload
設定開機啟動:systemctl enable *.service
啟動服務:systemctl start *.service
停止服務:systemctl stop *.service
重啟服務:systemctl reload *.service
注:修改完配置檔案要過載配置檔案。
Linux 自製系統服務啟動指令碼
在linux的某些系統服務中,需要自己定製啟動服務的指令碼。通常會使用cash語句來實現。一般用於程式啟動指令碼 syntax case 1in param1 commands param2 commands commands esacexample bin bash e bin bash e 表示...
指令碼變為系統服務
建立系統服務 您現在應該能夠從命令列執行指令碼,每分鐘傳輸一次溫度,壓力和濕度資料。但是,為了確保持續傳送資料,最好啟用乙個新服務,該服務將在伺服器重新啟動時自動執行指令碼。將指令碼複製到 usr bin 並使其可執行 sudo cp my.py usr bin my.py sudo chmod x...
Nginx在Linux中系統服務配置指令碼
以下 是在前人的基礎上,結合自己伺服器實際情況修改的,本人伺服器環境是 centos 6.3 1 建立啟動指令碼,root使用者執行 vi etc init.d nginx 儲存如下指令碼 2 為nginx指令碼新增許可權 chmod a x etc init.d nginx 3 新增nginx服務...