CentOS7使用systemctl添加自定義服務


一、簡介

Centos7開機第一個程序從init完全換成了systemd這種啟動方式,同centos 5 6已經是實質差別。systemd是靠管理unit的方式來控制開機服務,開機級別等功能。

在/usr/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字段定義啟動類型。它可以設置的值如下:

simple(默認值):ExecStart字段啟動的進程為主進程

forking:ExecStart字段將以fork()方式啟動,此時父進程將會退出,子進程將成為主進程(后台運行)

oneshot:類似於simple,但只執行一次,Systemd 會等它執行完,才啟動其他服務

dbus:類似於simple,但會等待 D-Bus 信號后啟動

notify:類似於simple,啟動結束后會發出通知信號,然后 Systemd 再啟動其他服務

idle:類似於simple,但是要等到其他任務都執行完,才會啟動該服務。一種使用場合是為讓該服務的輸出,不與其他服務的輸出相混合

 

  • 重啟行為

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:不管是什么退出原因,總是重啟

注:對於守護進程,推薦設為on-failure。對於那些允許發生錯誤退出的服務,可以設為on-abnormal。

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${NETWORKMANAGER}" = xyes

ExecStart=/home/mobileoa/apps/shMediaManager.sh -start

ExecReload=

ExecStop=/home/mobileoa/apps/shMediaManager.sh -stop

 

#創建私有的內存臨時空間

PrivateTmp=True

 

[Install]

#多用戶

WantedBy=multi-user.target

重載系統服務:systemctl daemon-reload

設置開機啟動:systemctl enable *.service

啟動服務:systemctl start *.service

停止服務:systemctl stop *.service

重啟服務:systemctl reload *.service

 

注:修改完配置文件要重載配置文件。

 

作者:風吹我已散博客

鏈接:https://www.jianshu.com/p/79059b06a121

來源:簡書

簡書著作權歸作者所有,任何形式的轉載都請聯系作者獲得授權並注明出處。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM