supervisor overview

supervisor:一個進程管理系統(tǒng)

  • supervisor是一個客戶端服務端皆可用的進程管理系統(tǒng)锡凝,用戶可以用它來監(jiān)控和管理類unix操作系統(tǒng)上的一系列進程
  • supervisor和launchd,daemontools,runit這些進程管理工具類似,但supervisor并不是“process id 1”的初始化代替者量九,而是作為進程和項目/用戶關(guān)系的控制系統(tǒng)

一乳愉、supervisor概述:

  • 便利性:supervisor是將需要管理的服務進程作為它的子進程的方式啟動的偷遗,在進程出現(xiàn)crash的情況下可以自動重啟驶忌,而且直接通過配置就可以在supervisor服務啟動時直接啟動想要管理進程戴尸;不必要像rc.d腳本那樣,逐個為進程編寫各異的琅捏、復雜的初始化命令生百,而且避免了rc.d腳本在進程crash后不自動重啟服務的問題
  • 精準性:Unix下面監(jiān)控一個進程up/down的精準狀態(tài)是比較難的,.pid文件標記進程狀態(tài)也不是很可靠柄延;但是supervisor將進程作為子進程啟動的方式蚀浆,就保證了它可以一直知道它子進程的當前狀態(tài),而且可以方便的查詢到狀態(tài)信息
  • “監(jiān)管委托”:很多時候用戶只是需要控制進程狀態(tài)拦焚,一個進程運行過程中并不想也不需要充分的shell操作權(quán)限蜡坊,可監(jiān)聽TCP端口的一些進程往往會需要root用戶才能進行啟動或重啟;但是通常這種情況下赎败,普通用戶需要可以終止或者重啟一個進程秕衙,但是提供給普通用戶的權(quán)限往往是不夠用的,同時很多時候我們不能任意提供普通用戶root權(quán)限或者sudo權(quán)限僵刮;找各種情況下据忘,supervisor作為root用戶啟動鹦牛,那就可以允許普通用戶通過supervisor去控制進程了;supervisor被賦予了有限的操作權(quán)限后勇吊,允許用戶查看進程狀態(tài)曼追,直接通過 stop, start, restart這些簡單的命令就可以控制supervisor管理下的子進程
  • 進程組管理:有時候進程需要成組或者是按照一定的優(yōu)先順序進行啟動或者終止操作,這個時候很難解釋給用戶怎么樣做控制汉规,而supervisor允許用戶給進程分配優(yōu)先級礼殊,也允許用戶通過supervisorctl客戶端調(diào)用start all,restart all這些命令去批量啟動或者重啟服務進程;這些進程可以被編輯分組针史,并配置好他們之間的邏輯關(guān)系作為一個進程組進行進程管理

二晶伦、supervisor的優(yōu)勢:

  • 簡單:supervisor通過固定的.ini格式配置管理的,這個.ini文件有固定的格式啄枕,按照約定的格式編寫配置婚陪,直接可以實現(xiàn)crash重啟、日志回旋的功能频祝,而且很容易上手
  • 集中:supervisor提供了一系列進程的管理方法泌参,既可以分別管理進程也可以組管理進程;可以通過配置讓supervisor實現(xiàn)本地/遠程命令行控制常空,甚至是web界面方式進行進程管理
  • 高效:supervisor通過fork/exec 啟動子進程沽一,一些管理工具那樣依賴PID文件或者定期檢測的方式重啟失敗進程,但是supervisor不一樣漓糙,因為在進程終止的時候锯玛,操作系統(tǒng)會立刻發(fā)消息給supervisor
  • 擴展:supervisor有個簡單的事件通知協(xié)議,無論是哪一種開發(fā)語言開發(fā)的工程都可以用supervisor來監(jiān)控兼蜈,而且還有個XML-RPC interface來管控攘残;在python程序開發(fā)過程中supervisor可以直接作為擴展點使用
  • 兼容:supervisor可以運行在除windows外的任意操作系統(tǒng)里:Linux, Mac OS X, Solaris, and FreeBSD都是支持的;加上supervisor是基于python語言實現(xiàn)的为狸,所以也不強求C語言編譯器

三歼郭、supervisor的組件:

supervisord:

  • supervisord負責啟動子項目作為supervisor的子進程,響應supervisor client的命令辐棒,重啟crash掉或者已經(jīng)存在的子進程病曾,以標準輸入輸出記錄子進程的log,在子進程生命周期內(nèi)生成和把控點對點的事件通信
  • 一般服務配置寫在/etc/supervisord.conf中漾根,文件中包含子進程管理的.ini文件即可泰涂,需要關(guān)注的就是文件的權(quán)限管理問題,因為權(quán)限配置對于子進程的一些數(shù)據(jù)和文件的使用是有影響的

supervisorctl:

  • supervisorctl相當于supervisor的命令行客戶端辐怕,把supervisord提供的功能做了封裝逼蒙,讓用戶可以通過supervisorctl連接不同的supervisord進程,獲取子進程狀態(tài)寄疏,啟動或終止子進程是牢,還可以查看當前supervisord下運行的進程有哪些
  • 這個命令行客戶端負責和unix內(nèi)部或TCP socket交流僵井;在服務允許用戶執(zhí)行命令之前,一個服務可以斷言當前客戶端的用戶是否應該提供用戶身份憑據(jù)
  • supervisorctl客戶端通常是和supervisord服務使用一個配置文件驳棱,但是任何一個[supervisorctl]下的配置文件都可以運行

Web Server:

  • 如果你啟動supervisord的時候啟用了internet端口批什,一個和supervisorctl功能類似的web用戶界面就可以直接通過瀏覽器訪問;在激活[inet_http_server]模塊配置以后社搅,用戶可以通過類似http://localhost:9001/這樣的地址驻债,直接查看和控制進程狀態(tài)

XML-RPC接口

  • 啟動一個XML-RPC的web服務和http的web服務是一樣的,都可以用來查詢和控制supervisor和項目的運行狀態(tài)

四形葬、平臺要求:

  • linux和Mac OS均可以支持却汉,但是windows不支持;
  • python3.4或者python2.7版本可以更好的兼容supervisor荷并,目前為止python2.6及以上版本都支持supervisor的使用
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市青扔,隨后出現(xiàn)的幾起案子源织,更是在濱河造成了極大的恐慌,老刑警劉巖微猖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谈息,死亡現(xiàn)場離奇詭異,居然都是意外死亡凛剥,警方通過查閱死者的電腦和手機侠仇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來犁珠,“玉大人逻炊,你說我怎么就攤上這事±缦恚” “怎么了余素?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長炊昆。 經(jīng)常有香客問我桨吊,道長,這世上最難降的妖魔是什么凤巨? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任视乐,我火速辦了婚禮,結(jié)果婚禮上敢茁,老公的妹妹穿的比我還像新娘佑淀。我一直安慰自己,他們只是感情好彰檬,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布渣聚。 她就那樣靜靜地躺著独榴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奕枝。 梳的紋絲不亂的頭發(fā)上棺榔,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天,我揣著相機與錄音隘道,去河邊找鬼症歇。 笑死,一個胖子當著我的面吹牛谭梗,可吹牛的內(nèi)容都是我干的忘晤。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼激捏,長吁一口氣:“原來是場噩夢啊……” “哼设塔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起远舅,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤闰蛔,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后图柏,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體序六,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年蚤吹,在試婚紗的時候發(fā)現(xiàn)自己被綠了例诀。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡裁着,死狀恐怖繁涂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情二驰,我是刑警寧澤爆土,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站诸蚕,受9級特大地震影響步势,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜背犯,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一坏瘩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧漠魏,春花似錦倔矾、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丰包。三九已至,卻和暖如春壤巷,著一層夾襖步出監(jiān)牢的瞬間邑彪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工胧华, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留寄症,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓矩动,卻偏偏與公主長得像有巧,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子悲没,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

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