superlance 命令

superlance介紹

superlance就是基于supervisor的事件機(jī)制實(shí)現(xiàn)的一系列命令行的工具集,它實(shí)現(xiàn)了許多supervisor本身沒(méi)有實(shí)現(xiàn)的實(shí)用的進(jìn)程監(jiān)控和管理的特性,包括內(nèi)存監(jiān)控昨寞,http接口監(jiān)控蝇裤,郵件和短信通知機(jī)制等巧勤。同樣的惹想,superlance本身也是使用python編寫(xiě)的


superlance命令

superlance是一系列命令行工具的集合拣凹,其包括以下這些命令:

httpok

通過(guò)定時(shí)對(duì)一個(gè)HTTP接口進(jìn)行GET請(qǐng)求森爽,根據(jù)請(qǐng)求是否成功來(lái)判定一個(gè)進(jìn)程是否處于正常狀態(tài),如果不正常則對(duì)進(jìn)程進(jìn)行重啟嚣镜。

crashmail

當(dāng)一個(gè)進(jìn)程意外退出時(shí)爬迟,發(fā)送郵件告警。

memmon

當(dāng)一個(gè)進(jìn)程的內(nèi)存占用超過(guò)了設(shè)定閾值時(shí)菊匿,發(fā)送郵件告警付呕。

crashmailbatch

類(lèi)似于crashmail的告警,但是一段時(shí)間內(nèi)的郵件將會(huì)被合成起來(lái)發(fā)送跌捆,以避免郵件轟炸徽职。

fatalmailbatch

當(dāng)一個(gè)進(jìn)程沒(méi)有成功啟動(dòng)多次后會(huì)進(jìn)入FATAL狀態(tài),此時(shí)發(fā)送郵件告警佩厚。與crashmailbatch一樣會(huì)進(jìn)行合成報(bào)警姆钉。

crashsms

當(dāng)一個(gè)進(jìn)程意外退出時(shí)發(fā)送短信告警,這個(gè)短信也是通過(guò)email網(wǎng)關(guān)來(lái)發(fā)送的

1.當(dāng)supervisord啟動(dòng)的時(shí)候抄瓦,如果我們的listener配置為autostart=true的話潮瓶,listener就會(huì)作為supervisor的子進(jìn)程被啟動(dòng)。2.listener被啟動(dòng)之后闺鲸,會(huì)向自己的stdout寫(xiě)一個(gè)"READY"的消息,此時(shí)父進(jìn)程也就是supervisord讀取到這條消息后筋讨,會(huì)認(rèn)為listener處于就緒狀態(tài)埃叭。3.listener處于就緒狀態(tài)后摸恍,當(dāng)supervisord產(chǎn)生的event在listener的配置的可接受的events中時(shí),supervisord就會(huì)把該event發(fā)送給該listener赤屋。4.listener接收到event后立镶,我們就可以根據(jù)event的head,body里面的數(shù)據(jù)类早,做一系列的處理了媚媒。我們根據(jù)event的內(nèi)容,判斷涩僻,提取缭召,報(bào)警等等操作栈顷。5.該干的活都干完之后,listener需要向自己的stdout寫(xiě)一個(gè)消息"RESULTnOK"嵌巷,supervisord接受到這條消息后萄凤。就知道listener處理event完畢了。


Supervisord支持的Event

PROCESS_STATE??? 進(jìn)程狀態(tài)發(fā)生改變

PROCESS_STATE_STARTING? 進(jìn)程狀態(tài)從其他狀態(tài)轉(zhuǎn)換為正在啟動(dòng)(Supervisord的配置項(xiàng)中有startsecs配置項(xiàng)搪哪, 是指程序啟動(dòng)時(shí)需要程序至少穩(wěn)定運(yùn)行x秒才認(rèn)為程序運(yùn)行正常靡努,在這x秒中程序狀態(tài)為正在啟動(dòng))

PROCESS_STATE_RUNNING?? 進(jìn)程狀態(tài)由正在啟動(dòng)轉(zhuǎn)換為正在運(yùn)行

PROCESS_STATE_BACKOFF?? 進(jìn)程狀態(tài)由正在啟動(dòng)轉(zhuǎn)換為失敗

PROCESS_STATE_STOPPING?? 進(jìn)程狀態(tài)由正在運(yùn)行轉(zhuǎn)換為正在停止

PROCESS_STATE_EXITED?? 進(jìn)程狀態(tài)由正在運(yùn)行轉(zhuǎn)換為退出

PROCESS_STATE_STOPPED?? 進(jìn)程狀態(tài)由正在停止轉(zhuǎn)換為已經(jīng)停止(exited和stopped的區(qū)別是exited是程序自行退出,而stopped為人為控制其退出)

PROCESS_STATE_FATAL?? 進(jìn)程狀態(tài)由正在運(yùn)行轉(zhuǎn)換為失敗

PROCESS_STATE_UNKNOWN?? 未知的進(jìn)程狀態(tài)

REMOTE_COMMUNICATION?? 使用Supervisord的RPC接口與Supervisord進(jìn)行通信

PROCESS_LOG?? 進(jìn)程產(chǎn)生日志輸出晓折,包括標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯(cuò)誤輸出

PROCESS_LOG_STDOUT?? 進(jìn)程產(chǎn)生標(biāo)準(zhǔn)輸出

PROCESS_LOG_STDERR?? 進(jìn)程產(chǎn)生標(biāo)準(zhǔn)錯(cuò)誤輸出

PROCESS_COMMUNICATION?? 進(jìn)程的日志輸出包含 和

PROCESS_COMMUNICATION_STDOUT?? 進(jìn)程的標(biāo)準(zhǔn)輸出包含 和

PROCESS_COMMUNICATION_STDERR?? 進(jìn)程的標(biāo)準(zhǔn)錯(cuò)誤輸出包含 和

SUPERVISOR_STATE_CHANGE_RUNNING Supervisord? 啟動(dòng)

SUPERVISOR_STATE_CHANGE_STOPPING Supervisord? 停止

TICK_5?? 每隔5秒觸發(fā)

TICK_60?? 每隔60秒觸發(fā)

TICK_3600?? 每隔3600觸發(fā)

PROCESS_GROUP?? Supervisord的進(jìn)程組發(fā)生變化

PROCESS_GROUP_ADDED?? 新增了Supervisord的進(jìn)程組

PROCESS_GROUP_REMOVED?? 刪除了Supervisord的進(jìn)程組

安裝superlance

也是python程序惑朦,直接pip 安裝


pip install superlance


既然有了上面的event特性,下面就配置一個(gè)發(fā)郵件報(bào)警漓概,當(dāng)nginx莫名其妙的重啟后 就立刻發(fā)郵件通知漾月。

這里在說(shuō)一下,centos下如何用命令行直接發(fā)郵件的垛耳,我一直都沒(méi)有用過(guò)默認(rèn) 自帶的栅屏,也不好用。推薦一個(gè)比較好用的堂鲜。

sendEmail,用perl語(yǔ)言寫(xiě)好的 也都封裝好了犬金,只需要提供發(fā)件人 郵箱賬號(hào) 密碼 smtp服務(wù) 收件人 就可以了。

先配置一下


wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gztar zxvf sendEmail-v1.56.tar.gz

cp sendEmail-v1.56/sendEmail /usr/bin/sendemail


ok丙者,發(fā)郵件測(cè)試一下扎唾,這里我把郵箱信息隱藏一下了.....


sendemail -f 發(fā)件人郵箱 -t 收件人郵箱 -s 發(fā)件人郵箱smtp服務(wù)器 -u"sendEmail"-m"haha"-xu 發(fā)件人郵箱 -xp 發(fā)件人郵箱密碼

-f 發(fā)件人-t 收件人-s 發(fā)件人smtp服務(wù)器-u 主題-m 內(nèi)容-xu 發(fā)件人用戶名-xp 發(fā)件人密碼


我這里用的163發(fā)的 qq郵箱收件的,測(cè)試沒(méi)啥問(wèn)題的痴奏。




ok 現(xiàn)在要做的就是配置一個(gè)supervisor配置文件蛀骇,來(lái)一直監(jiān)聽(tīng)進(jìn)程的狀態(tài)變化


[root@test?/]# cat /etc/supervisor/config.d/mail.conf

[eventlistener:crashmail-exited]

command=crashmail?-a?-s?"/usr/bin/sendemail -f xxxxxx@163.com -t xxxxxx@qq.com -s smtp.163.com -u 'nginx' -xu xxxxxxx@163.com -xp xxxxxxxx -m"?-m xxxxxxxx@qq.com

events=PROCESS_STATE_EXITED

redirect_stderr=false

添加好一個(gè)進(jìn)程配置文件后,supervisorctl reload 重啟一下



已經(jīng)是兩個(gè)進(jìn)程在running了

下面測(cè)試一下 kill 掉nginx進(jìn)程


ps aux | grep nginx

kill -91765917660



然后看一下supervisor




此時(shí) nginx pid已經(jīng)變化读拆,說(shuō)明kill之后 又被拉起來(lái)了擅憔。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市檐晕,隨后出現(xiàn)的幾起案子暑诸,更是在濱河造成了極大的恐慌,老刑警劉巖辟灰,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件个榕,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡芥喇,警方通過(guò)查閱死者的電腦和手機(jī)西采,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)继控,“玉大人械馆,你說(shuō)我怎么就攤上這事胖眷。” “怎么了霹崎?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵瘦材,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我仿畸,道長(zhǎng)食棕,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任错沽,我火速辦了婚禮簿晓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘千埃。我一直安慰自己憔儿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布放可。 她就那樣靜靜地躺著谒臼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪耀里。 梳的紋絲不亂的頭發(fā)上蜈缤,一...
    開(kāi)封第一講書(shū)人閱讀 52,441評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音冯挎,去河邊找鬼底哥。 笑死,一個(gè)胖子當(dāng)著我的面吹牛房官,可吹牛的內(nèi)容都是我干的趾徽。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼翰守,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼孵奶!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起蜡峰,我...
    開(kāi)封第一講書(shū)人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤了袁,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后事示,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體早像,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡僻肖,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年肖爵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片臀脏。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡劝堪,死狀恐怖冀自,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情秒啦,我是刑警寧澤熬粗,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站余境,受9級(jí)特大地震影響驻呐,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜芳来,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一含末、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧即舌,春花似錦佣盒、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至紊搪,卻和暖如春蜜葱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背耀石。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工笼沥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人娶牌。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓奔浅,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親诗良。 傳聞我的和親對(duì)象是個(gè)殘疾皇子汹桦,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

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