您好,登錄后才能下訂單哦!
項(xiàng)目中遇到有些腳本需要通過后臺(tái)進(jìn)程運(yùn)行,保證不被異常中斷,之前都是通過nohup、&、screen來實(shí)現(xiàn),帶著能否做一個(gè)start/stop/restart/reload的服務(wù)啟動(dòng)的想法找到里Supervisor。關(guān)于supervisor的介紹在網(wǎng)上大致搜索總結(jié)如下:
Supervisor是用Python開發(fā)的一套通用的進(jìn)程管理程序,能將一個(gè)普通的命令行進(jìn)程變?yōu)楹笈_(tái)daemon,并監(jiān)控進(jìn)程狀態(tài),異常退出時(shí)能自動(dòng)重啟。它是通過fork/exec的方式把這些被管理的進(jìn)程當(dāng)作supervisor的子進(jìn)程來啟動(dòng),這樣只要在supervisor的配置文件中,把要管理的進(jìn)程的可執(zhí)行文件的路徑寫進(jìn)去即可。也實(shí)現(xiàn)當(dāng)子進(jìn)程掛掉的時(shí)候,父進(jìn)程可以準(zhǔn)確獲取子進(jìn)程掛掉的信息的,可以選擇是否自己啟動(dòng)和報(bào)警。supervisor還提供了一個(gè)功能,可以為supervisord或者每個(gè)子進(jìn)程,設(shè)置一個(gè)非root的user,這個(gè)user就可以管理它對(duì)應(yīng)的進(jìn)程。
1,安裝
1:easy_install 安裝: easy_install supervisor2:pip 安裝: pip install supervisor3:Debian / Ubuntu可以直接通過apt安裝: apt-get install supervisor
2,配置文件
1)通過apt-get install安裝后,supervisor的配置文件在:
/etc/supervisor/supervisord.conf
supervisor的配置文件默認(rèn)是不全的,不過在大部分默認(rèn)的情況下,上面說的基本功能已經(jīng)滿足。而其管理的子進(jìn)程配置文件在:
/etc/supervisor/conf.d/*.conf
然后,開始給自己需要的腳本程序編寫一個(gè)子進(jìn)程配置文件,讓supervisor來管理它,放在/etc/supervisor/conf.d/目錄下,以.conf作為擴(kuò)展名(每個(gè)進(jìn)程的配置文件都可以單獨(dú)分拆也可以把相關(guān)的腳本放一起)。如任意定義一個(gè)和腳本相關(guān)的項(xiàng)目名稱的選項(xiàng)組(/etc/supervisor/conf.d/test.conf):
#項(xiàng)目名[program:blog] #腳本目錄 directory=/opt/bin #腳本執(zhí)行命令 command=/usr/bin/python /opt/bin/test.py #supervisor啟動(dòng)的時(shí)候是否隨著同時(shí)啟動(dòng),默認(rèn)True autostart=true #當(dāng)程序exit的時(shí)候,這個(gè)program不會(huì)自動(dòng)重啟,默認(rèn)unexpected #設(shè)置子進(jìn)程掛掉后自動(dòng)重啟的情況,有三個(gè)選項(xiàng),false,unexpected和true。如果為false的時(shí)候,無論什么情況下,都不會(huì)被重新啟動(dòng),如果為unexpected,只有當(dāng)進(jìn)程的退出碼不在下面的exitcodes里面定義的 autorestart=false #這個(gè)選項(xiàng)是子進(jìn)程啟動(dòng)多少秒之后,此時(shí)狀態(tài)如果是running,則我們認(rèn)為啟動(dòng)成功了。默認(rèn)值為1 startsecs=1 #日志輸出 stderr_logfile=/tmp/blog_stderr.log stdout_logfile=/tmp/blog_stdout.log #腳本運(yùn)行的用戶身份 user = zhoujy #把 stderr 重定向到 stdout,默認(rèn) false redirect_stderr = true #stdout 日志文件大小,默認(rèn) 50MB stdout_logfile_maxbytes = 20M #stdout 日志文件備份數(shù) stdout_logfile_backups = 20 [program:zhoujy] #說明同上 directory=/opt/bin command=/usr/bin/python /opt/bin/zhoujy.py autostart=true autorestart=false stderr_logfile=/tmp/zhoujy_stderr.log stdout_logfile=/tmp/zhoujy_stdout.log #user = zhoujy
2)通過easy_install安裝后,配置文件不存在,需要自己導(dǎo)入。
①:運(yùn)行echo_supervisord_conf打印出一個(gè)配置文件的樣本,樣本說明可以看supervisor(一)基礎(chǔ)篇的詳細(xì)說明,要是設(shè)置樣本為一個(gè)配置文件則:
1:運(yùn)行 echo_supervisord_conf,查看配置樣本: echo_supervisord_conf2:創(chuàng)建配置文件: echo_supervisord_conf > /etc/supervisord.conf
②:配置子進(jìn)程配置文件,可以直接在supervisor中的;[program:theprogramname]里設(shè)置。
詳細(xì)的子進(jìn)程配置文件:
樣本:
View Code
說明:
View Code
改成自己實(shí)際的配置文件:和①上面一樣。
3:運(yùn)行
1)apt-get install 安裝的supervisor直接可以通過 /etc/init.d/supervisor 運(yùn)行:
/etc/init.d/supervisor start
2)通過easy_install 安裝的supervisor運(yùn)行supervisord 運(yùn)行:
supervisord
4:web界面操作
需要在supervisor的配置文件里添加[inet_http_server]選項(xiàng)組:之后可以通過http://10.211.55.11:9001來訪問控制子線程的管理。
[inet_http_server] port=10.211.55.11:9001username=user password=123
效果:
5:子進(jìn)程管理(supervisorctl)
1) 查看所有子進(jìn)程的狀態(tài):
# supervisorctl statusblog RUNNING pid 2395, uptime 0:08:41zhoujy RUNNING pid 2396, uptime 0:08:41
2)關(guān)閉、開啟指定的子進(jìn)程:
# supervisorctl stop zhoujyzhoujy: stopped # supervisorctl start zhoujyzhoujy: started
3)關(guān)閉、開啟所有的子進(jìn)程:
# supervisorctl stop allblog: stopped zhoujy: stopped # supervisorctl start allblog: started zhoujy: started
4):其他參數(shù):supervisor開啟后子進(jìn)程自動(dòng)開啟(autostart=true)和子進(jìn)程退出后自動(dòng)啟動(dòng)(autorestart=ture)
更多的參數(shù)可以看官方文檔和supervisor(一)基礎(chǔ)篇的說明。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。