Supervisor 讓崩潰的程序自動重啟

Supervisor 介紹

Supervisor 是一個用 Python 寫的進程管理工具锋喜,可以很方便的用來啟動扣孟、重啟盼铁、關(guān)閉進程(不僅僅是 Python 進程)醋粟。除了對單個進程的控制仗阅,還可以同時啟動昌讲、關(guān)閉多個進程,比如很不幸的服務(wù)器由于某種原因暫時 kill 掉你的應(yīng)用减噪,此時可以用 Supervisor 讓你的應(yīng)用自動重啟短绸,如果是多個應(yīng)用被殺死,也省去了手動一個一個地敲命令重新啟動筹裕。

安裝

目前 Supervisor 只能運行在 Unix-Like 的系統(tǒng)上醋闭,無法運行在 Windows 上。Supervisor 官方版目前只能運行在 Python 2.4 以上版本朝卒,但是還無法運行在 Python 3 上目尖。執(zhí)行下面代碼前,需要安裝 pip

pip install supervisor

安裝完成后扎运,可以使用兩個命令瑟曲,分別是 supervisordsupervisorctl,如果你的系統(tǒng)里有兩個版本的 Python,且默認的 python 命令版本是 Python 3,此時運行會出錯豪治,解決方式是修改兩個命令使用的 Python 版本洞拨。使用 which 命令找到兩個命令的文件地址,然后編輯文件并指定 Python 版本:

修改 Python 版本

編輯配置文件

將下面內(nèi)容保存到 /etc/supervisor/supervisord.conf:

; 基礎(chǔ)配置樣例

[unix_http_server]
file=/var/run/supervisor.sock   ; (the path to the socket file)
chmod=0700                       ; sockef file mode (default 0700)

[supervisord]
logfile=/var/log/supervisor/supervisord.log ; (main log file;default $CWD/supervisord.log)
pidfile=/var/run/supervisord.pid ; (supervisord pidfile;default supervisord.pid)
childlogdir=/var/log/supervisor            ; ('AUTO' child log dir, default $TEMP)

; the below section must remain in the config file for RPC
; (supervisorctl/web interface) to work, additional interfaces may be
; added by defining them in separate rpcinterface: sections
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[supervisorctl]
serverurl=unix:///var/run/supervisor.sock ; use a unix:// URL  for a unix socket

; The [include] section can just contain the "files" setting.  This
; setting can list multiple files (separated by whitespace or
; newlines).  It can also contain wildcards.  The filenames are
; interpreted as relative to this file.  Included files *cannot*
; include files themselves.

[include]
files = /etc/supervisor/conf.d/*.conf ;加載其他配置文件

[inet_http_server]         ; inet (TCP) server disabled by default
port=*:9001                ; 通過網(wǎng)頁可以控制子進程
;username=user              ; (default is no username (open server))
;password=123               ; (default is no password (open server))

; 進程的配置樣例

; 設(shè)置進程的名稱负拟,使用 supervisorctl 來管理進程時需要使用該進程名烦衣,這里的進程名是 your_program_name
[program:your_program_name] 
;numprocs=1                 ; 進程數(shù)量,默認為1
;process_name=%(program_name)s   ; 默認為 %(program_name)s,即 [program:x] 中的 x
directory=/home/yiming ; 執(zhí)行 command 之前花吟,先切換到工作目錄
command=python test.py
autostart=true ;如果設(shè)置為true秸歧,當(dāng)supervisord啟動的時候,進程會自動重啟衅澈。
user=yiming                 ; 使用 yiming 用戶來啟動該進程
autorestart=true   ; 程序崩潰時自動重啟键菱,重啟次數(shù)是有限制的,默認為3次
startsecs = 5        ; 啟動 5 秒后沒有異常退出今布,就當(dāng)作已經(jīng)正常啟動了           
redirect_stderr=true        ; 錯誤日志重定向到標(biāo)準(zhǔn)輸出
loglevel=info


現(xiàn)在以守護進程的方式啟動 test.py

supervisord -c /etc/supervisor/supervisord.conf

此時命令 python test.ty 已經(jīng)被執(zhí)行经备,因為進程配置樣例中有 autostart=true,所以 Supervisord 服務(wù)運行后啟動進程 your_program_name 部默,并把 your_program_name 進程作為自己的子進程侵蒙,所以當(dāng)進程 your_program_name 掛掉后,Supervisord 會收到通知傅蹂,然后可以再次將 your_program_name 作為子進程啟動纷闺。

模擬程序異常退出

如下圖,名稱為 echo 的進程被殺掉兩次份蝴,之后都會被重新啟動急但,右側(cè)是 Supervisord 日志記錄了 echo 進程狀態(tài)的變化:

功能演示

使用 supervisorctl 管理進程

  • 停止某一個進程,program_name 為 [program:x] 里的 x:
supervisorctl stop program_name
  • 啟動某個進程:
supervisorctl start program_name
  • 重啟某個進程:
supervisorctl restart program_name
  • 停止全部進程搞乏,注:start波桩、restart、stop 都不會載入最新的配置文件:
supervisorctl stop all
  • 載入最新的配置文件请敦,停止原有進程并按新的配置啟動镐躲、管理所有進程:
supervisorctl reload
  • 根據(jù)最新的配置文件,啟動新配置或有改動的進程侍筛,配置沒有改動的進程不會受影響而重啟:
supervisorctl update

Web 管理

Web 管理進程

Supervisor 可以在界面上管理進程萤皂,Web Server 其實是通過 XML_RPC 來實現(xiàn)的,可以向Supervisor 請求數(shù)據(jù)匣椰,也可以控制 Supervisor 及子進程裆熙。配置在 [inet_http_server] 塊里面:

[inet_http_server]         ; inet (TCP) server disabled by default
port=*:9001                ; 通過網(wǎng)頁可以控制子進程
;username=user              ; (default is no username (open server))
;password=123               ; (default is no password (open server))

配置參數(shù)介紹

參數(shù) 參數(shù)解釋
command 啟動程序使用的命令,可以是絕對路徑或者相對路徑
process_name 一個python字符串表達式禽笑,用來表示supervisor進程啟動的這個的名稱入录,默認值是%(program_name)s
numprocs Supervisor啟動這個程序的多個實例,如果numprocs>1佳镜,則process_name的表達式必須包含%(process_num)s僚稿,默認是1
numprocs_start 一個int偏移值,當(dāng)啟動實例的時候用來計算numprocs的值
priority 權(quán)重蟀伸,可以控制程序啟動和關(guān)閉時的順序蚀同,權(quán)重越低:越早啟動缅刽,越晚關(guān)閉。默認值是999
autostart 如果設(shè)置為true蠢络,當(dāng)supervisord啟動的時候衰猛,進程會自動重啟。
autorestart 值可以是false刹孔、true啡省、unexpected。false:進程不會自動重啟芦疏,unexpected:當(dāng)程序退出時的退出碼不是exitcodes中定義的時冕杠,進程會重啟微姊,true:進程會無條件重啟當(dāng)退出的時候酸茴。
startsecs 程序啟動后等待多長時間后才認為程序啟動成功
startretries supervisord嘗試啟動一個程序時嘗試的次數(shù)。默認是3
exitcodes 一個預(yù)期的退出返回碼兢交,默認是0,2薪捍。
stopsignal 當(dāng)收到stop請求的時候,發(fā)送信號給程序配喳,默認是TERM信號酪穿,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2。
stopwaitsecs 在操作系統(tǒng)給supervisord發(fā)送SIGCHILD信號時等待的時間
stopasgroup 如果設(shè)置為true晴裹,則會使supervisor發(fā)送停止信號到整個進程組
killasgroup 如果設(shè)置為true被济,則在給程序發(fā)送SIGKILL信號的時候,會發(fā)送到整個進程組涧团,它的子進程也會受到影響只磷。
user 如果supervisord以root運行,則會使用這個設(shè)置用戶啟動子程序
redirect_stderr 如果設(shè)置為true泌绣,進程則會把標(biāo)準(zhǔn)錯誤輸出到supervisord后臺的標(biāo)準(zhǔn)輸出文件描述符钮追。
stdout_logfile 把進程的標(biāo)準(zhǔn)輸出寫入文件中,如果stdout_logfile沒有設(shè)置或者設(shè)置為AUTO阿迈,則supervisor會自動選擇一個文件位置元媚。
stdout_logfile_maxbytes 標(biāo)準(zhǔn)輸出log文件達到多少后自動進行輪轉(zhuǎn),單位是KB苗沧、MB刊棕、GB。如果設(shè)置為0則表示不限制日志文件大小
stdout_logfile_backups 標(biāo)準(zhǔn)輸出日志輪轉(zhuǎn)備份的數(shù)量待逞,默認是10鞠绰,如果設(shè)置為0,則不備份
stdout_capture_maxbytes 當(dāng)進程處于stderr capture mode模式的時候飒焦,寫入FIFO隊列的最大bytes值蜈膨,單位可以是KB屿笼、MB、GB
stdout_events_enabled 如果設(shè)置為true翁巍,當(dāng)進程在寫它的stderr到文件描述符的時候驴一,PROCESS_LOG_STDERR事件會被觸發(fā)
stderr_logfile 把進程的錯誤日志輸出一個文件中,除非redirect_stderr參數(shù)被設(shè)置為true
stderr_logfile_maxbytes 錯誤log文件達到多少后自動進行輪轉(zhuǎn)灶壶,單位是KB肝断、MB、GB驰凛。如果設(shè)置為0則表示不限制日志文件大小
stderr_logfile_backups 錯誤日志輪轉(zhuǎn)備份的數(shù)量胸懈,默認是10,如果設(shè)置為0恰响,則不備份
stderr_capture_maxbytes 當(dāng)進程處于stderr capture mode模式的時候趣钱,寫入FIFO隊列的最大bytes值,單位可以是KB胚宦、MB首有、GB
stderr_events_enabled 如果設(shè)置為true,當(dāng)進程在寫它的stderr到文件描述符的時候枢劝,PROCESS_LOG_STDERR事件會被觸發(fā)
environment 一個k/v對的list列表
directory supervisord在生成子進程的時候會切換到該目錄
umask 設(shè)置進程的umask
serverurl 是否允許子進程和內(nèi)部的HTTP服務(wù)通訊井联,如果設(shè)置為AUTO,supervisor會自動的構(gòu)造一個url
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末您旁,一起剝皮案震驚了整個濱河市烙常,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌鹤盒,老刑警劉巖蚕脏,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異昨悼,居然都是意外死亡蝗锥,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門率触,熙熙樓的掌柜王于貴愁眉苦臉地迎上來终议,“玉大人,你說我怎么就攤上這事葱蝗⊙ㄕ牛” “怎么了?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵两曼,是天一觀的道長皂甘。 經(jīng)常有香客問我,道長悼凑,這世上最難降的妖魔是什么偿枕? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任璧瞬,我火速辦了婚禮,結(jié)果婚禮上渐夸,老公的妹妹穿的比我還像新娘嗤锉。我一直安慰自己,他們只是感情好墓塌,可當(dāng)我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布瘟忱。 她就那樣靜靜地躺著,像睡著了一般苫幢。 火紅的嫁衣襯著肌膚如雪访诱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天韩肝,我揣著相機與錄音触菜,去河邊找鬼。 笑死伞梯,一個胖子當(dāng)著我的面吹牛玫氢,可吹牛的內(nèi)容都是我干的帚屉。 我是一名探鬼主播谜诫,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼攻旦!你這毒婦竟也來了喻旷?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤牢屋,失蹤者是張志新(化名)和其女友劉穎且预,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體烙无,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡锋谐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了截酷。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片涮拗。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖迂苛,靈堂內(nèi)的尸體忽然破棺而出三热,到底是詐尸還是另有隱情,我是刑警寧澤三幻,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布就漾,位于F島的核電站,受9級特大地震影響念搬,放射性物質(zhì)發(fā)生泄漏抑堡。R本人自食惡果不足惜摆出,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望首妖。 院中可真熱鬧懊蒸,春花似錦、人聲如沸悯搔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽妒貌。三九已至通危,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間灌曙,已是汗流浹背菊碟。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留在刺,地道東北人逆害。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像蚣驼,于是被迫代替她去往敵國和親魄幕。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,440評論 2 348

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