在python3中使用Supervisor的詳細教程
supervisor介紹
首先,介紹一下supervisor。Supervisor(http://supervisord.org)是用Python開發(fā)的一個client/server服務,是Linux/Unix系統(tǒng)下的一個進程管理工具,不支持Windows系統(tǒng)。它可以很方便的監(jiān)聽、啟動、停止、重啟一個或多個進程。用Supervisor管理的進程,當一個進程意外被殺死,supervisort監(jiān)聽到進程死后,會自動將它重新拉起,很方便的做到進程自動恢復的功能,不再需要自己寫shell腳本來控制
環(huán)境:centos7.4
安裝supervisor
pip install supervisor
因為是python開發(fā)的一個庫,可以直接用pip來安裝,很方便。
supervisor安裝完成后會生成三個執(zhí)行程序:supervisortd、supervisorctl、echo_supervisord_conf,分別是supervisor的守護進程服務(用于接收進程管理命令)、客戶端(用于和守護進程通信,發(fā)送管理進程的指令)、生成初始配置文件程序。
設置環(huán)境變量
$ vim ~/.bash_profile #在后面補充: PATH=$PATH:$HOME/bin:/usr/local/python/bin $ source ~/.bash_profile
配置supervisor
創(chuàng)建目錄,初始化配置文件
mkdir /etc/supervisor echo_supervisord_conf > /etc/supervisor/supervisord.conf
主配置文件參數(shù)
[unix_http_server] file=/tmp/supervisor.sock ; UNIX socket 文件,supervisorctl 會使用 ;chmod=0700 ; socket 文件的 mode,默認是 0700 ;chown=nobody:nogroup ; socket 文件的 owner,格式: uid:gid ;[inet_http_server] ; HTTP 服務器,提供 web 管理界面 ;port=127.0.0.1:9001 ; Web 管理后臺運行的 IP 和端口,如果開放到公網(wǎng),需要注意安全性 ;username=user ; 登錄管理后臺的用戶名 ;password=123 ; 登錄管理后臺的密碼 [supervisord] logfile=/tmp/supervisord.log ; 日志文件,默認是 $CWD/supervisord.log logfile_maxbytes=50MB ; 日志文件大小,超出會 rotate,默認 50MB logfile_backups=10 ; 日志文件保留備份數(shù)量默認 10 loglevel=info ; 日志級別,默認 info,其它: debug,warn,trace pidfile=/tmp/supervisord.pid ; pid 文件 nodaemon=false ; 是否在前臺啟動,默認是 false,即以 daemon 的方式啟動 minfds=1024 ; 可以打開的文件描述符的最小值,默認 1024 minprocs=200 ; 可以打開的進程數(shù)的最小值,默認 200 ; 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:///tmp/supervisor.sock ; 通過 UNIX socket 連接 supervisord,路徑與 unix_http_server 部分的 file 一致 ;serverurl=http://127.0.0.1:9001 ; 通過 HTTP 的方式連接 supervisord ; 包含其他的配置文件 [include] files = relative/directory/*.ini ; 可以是 *.conf 或 *.ini
管理一個進程
把所有被管理的進程配置文件都放在同一個目錄,主配置文件包含進去。
mkdir /etc/supervisor/config.d
vim /etc/supervisor/supervisord.conf [include] files = /etc/supervisor/config.d/*.conf
新建一個配置文件
[program:sougou] #souogu 為程序的名稱 command=scrapy crawl sougou #需要執(zhí)行的命令 directory=/home/mzj/桌面/sougou/sougou/wechat_name/wechat_name/spiders #命令執(zhí)行的目錄 environment=ASPNETCORE__ENVIRONMENT=Production #環(huán)境變量 user=root #用戶 stopsignal=INT autostart=true #是否自啟動 autorestart=true #是否自動重啟 startsecs=3 #自動重啟時間間隔(s) stderr_logfile=/home/mzj/桌面/sougou/sougou/wechat_name/wechat_name/spiders/ossoffical.err.log #錯誤日志文件 stdout_logfile=/home/mzj/桌面/sougou/sougou/wechat_name/wechat_name/spiders/ossoffical.out.log #輸出日志文件
[program:nginx] command = /usr/local/nginx/sbin/nginx -g 'daemon off;' startsecs = 3 autostart = true autorestart = true user = root stdout_logfile = /etc/supervisor/logs/supervisord-nginx.log stderr_logfile = /etc/supervisor/logs/supervisord-nginx-error.log
剛開始有個坑,command = /usr/local/nginx/sbin/nginx 我是這樣寫的 結果就一直啟動nginx 因為這樣的話 是后臺運行的nginx,然而supervisor 不能管理后臺運行進程,所以把nginx daemon off 守護關掉,就讓他阻塞在前臺bash運行,方便supervisor來管理。
supervisor配置文件詳解
- command:啟動程序使用的命令,可以是絕對路徑或者相對路徑
- process_name:一個python字符串表達式,用來表示supervisor進程啟動的這個的名稱,默認值是%(program_name)s
- numprocs:Supervisor啟動這個程序的多個實例,如果numprocs>1,則process_name的表達式必須包含%(process_num)s,默認是1
- numprocs_start:一個int偏移值,當啟動實例的時候用來計算numprocs的值
- priority:權重,可以控制程序啟動和關閉時的順序,權重越低:越早啟動,越晚關閉。默認值是999
- autostart:如果設置為true,當supervisord啟動的時候,進程會自動重啟。
- autorestart:值可以是false、true、unexpected。false:進程不會自動重啟,unexpected:當程序退出時的退出碼不是exitcodes中定義的時,進程會重啟,true:進程會無條件重啟當退出的時候。
- startsecs:程序啟動后等待多長時間后才認為程序啟動成功
- startretries:supervisord嘗試啟動一個程序時嘗試的次數(shù)。默認是3
- exitcodes:一個預期的退出返回碼,默認是0,2。
- stopsignal:當收到stop請求的時候,發(fā)送信號給程序,默認是TERM信號,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2。
- stopwaitsecs:在操作系統(tǒng)給supervisord發(fā)送SIGCHILD信號時等待的時間
- stopasgroup:如果設置為true,則會使supervisor發(fā)送停止信號到整個進程組
- killasgroup:如果設置為true,則在給程序發(fā)送SIGKILL信號的時候,會發(fā)送到整個進程組,它的子進程也會受到影響。
- user:如果supervisord以root運行,則會使用這個設置用戶啟動子程序
- redirect_stderr:如果設置為true,進程則會把標準錯誤輸出到supervisord后臺的標準輸出文件描述符。
- stdout_logfile:把進程的標準輸出寫入文件中,如果stdout_logfile沒有設置或者設置為AUTO,則supervisor會自動選擇一個文件位置。
- stdout_logfile_maxbytes:標準輸出log文件達到多少后自動進行輪轉(zhuǎn),單位是KB、MB、GB。如果設置為0則表示不限制日志文件大小
- stdout_logfile_backups:標準輸出日志輪轉(zhuǎn)備份的數(shù)量,默認是10,如果設置為0,則不備份
- stdout_capture_maxbytes:當進程處于stderr capture mode模式的時候,寫入FIFO隊列的最大bytes值,單位可以是KB、MB、GB
- stdout_events_enabled:如果設置為true,當進程在寫它的stderr到文件描述符的時候,PROCESS_LOG_STDERR事件會被觸發(fā)
- stderr_logfile:把進程的錯誤日志輸出一個文件中,除非redirect_stderr參數(shù)被設置為true
- stderr_logfile_maxbytes:錯誤log文件達到多少后自動進行輪轉(zhuǎn),單位是KB、MB、GB。如果設置為0則表示不限制日志文件大小
- stderr_logfile_backups:錯誤日志輪轉(zhuǎn)備份的數(shù)量,默認是10,如果設置為0,則不備份
- stderr_capture_maxbytes:當進程處于stderr capture mode模式的時候,寫入FIFO隊列的最大bytes值,單位可以是KB、MB、GB
- stderr_events_enabled:如果設置為true,當進程在寫它的stderr到文件描述符的時候,PROCESS_LOG_STDERR事件會被觸發(fā)
- environment:一個k/v對的list列表
- directory:supervisord在生成子進程的時候會切換到該目錄
- umask:設置進程的umask
- serverurl:是否允許子進程和內(nèi)部的HTTP服務通訊,如果設置為AUTO,supervisor會自動的構造一個url
啟動supervisor
supervisord -c /etc/supervisor/supervisord.conf
有時候kill進程之后需要釋放連接
unlink /tmp/supervisor.sock
web界面管理 開啟web訪問
vi /etc/supervisor/supervisord.conf [inet_http_server] port=0.0.0.0:9001 username=user password=123
此處需要注意將 [inet_http_server] 前邊的注釋也要去掉
supervisorctl的用法
- supervisord : 啟動supervisor
- supervisorctl reload :修改完配置文件后重新啟動supervisor
- supervisorctl status :查看supervisor監(jiān)管的進程狀態(tài)
- supervisorctl start 進程名 :啟動XXX進程
- supervisorctl stop 進程名 :停止XXX進程
- supervisorctl stop all:停止全部進程,注:start、restart、stop都不會載入最新的配置文件。
- supervisorctl update:根據(jù)最新的配置文件,啟動新配置或有改動的進程,配置沒有改動的進程不會受影響而重啟
superlance介紹
superlance就是基于supervisor的事件機制實現(xiàn)的一系列命令行的工具集,它實現(xiàn)了許多supervisor本身沒有實現(xiàn)的實用的進程監(jiān)控和管理的特性,包括內(nèi)存監(jiān)控,http接口監(jiān)控,郵件和短信通知機制等。同樣的,superlance本身也是使用python編寫的
superlance的組件
superlance是一系列命令行工具的集合,其包括以下這些命令:
- httpok 通過定時對一個HTTP接口進行GET請求,根據(jù)請求是否成功來判定一個進程是否處于正常狀態(tài),如果不正常則對進程進行重啟。
- crashmail 當一個進程意外退出時,發(fā)送郵件告警。
- memmon 當一個進程的內(nèi)存占用超過了設定閾值時,發(fā)送郵件告警。
- crashmailbatch 類似于crashmail的告警,但是一段時間內(nèi)的郵件將會被合成起來發(fā)送,以避免郵件轟炸。
- fatalmailbatch 當一個進程沒有成功啟動多次后會進入FATAL狀態(tài),此時發(fā)送郵件告警。與crashmailbatch一樣會進行合成報警。
- crashsms 當一個進程意外退出時發(fā)送短信告警,這個短信也是通過email網(wǎng)關來發(fā)送的。
1、當supervisord啟動的時候,如果我們的listener配置為autostart=true的話,listener就會作為supervisor的子進程被啟動。
2、listener被啟動之后,會向自己的stdout寫一個"READY"的消息,此時父進程也就是supervisord讀取到這條消息后,會認為listener處于就緒狀態(tài)。
3、listener處于就緒狀態(tài)后,當supervisord產(chǎn)生的event在listener的配置的可接受的events中時,supervisord就會把該event發(fā)送給該listener。
4、listener接收到event后,我們就可以根據(jù)event的head,body里面的數(shù)據(jù),做一系列的處理了。我們根據(jù)event的內(nèi)容,判斷,提取,報警等等操作。
5、該干的活都干完之后,listener需要向自己的stdout寫一個消息"RESULTnOK",supervisord接受到這條消息后。就知道listener處理event完畢了。
Supervisord支持的Event
- PROCESS_STATE 進程狀態(tài)發(fā)生改變
- PROCESS_STATE_STARTING
- 進程狀態(tài)從其他狀態(tài)轉(zhuǎn)換為正在啟動(Supervisord的配置項中有startsecs配置項,
- 是指程序啟動時需要程序至少穩(wěn)定運行x秒才認為程序運行正常,在這x秒中程序狀態(tài)為正在啟動)
- PROCESS_STATE_RUNNING 進程狀態(tài)由正在啟動轉(zhuǎn)換為正在運行
- PROCESS_STATE_BACKOFF 進程狀態(tài)由正在啟動轉(zhuǎn)換為失敗
- PROCESS_STATE_STOPPING 進程狀態(tài)由正在運行轉(zhuǎn)換為正在停止
- PROCESS_STATE_EXITED 進程狀態(tài)由正在運行轉(zhuǎn)換為退出
- PROCESS_STATE_STOPPED進程狀態(tài)由正在停止轉(zhuǎn)換為已經(jīng)停止(exited和stopped的區(qū)別是exited是程序自行退出,而stopped為人為控制其退出)
- PROCESS_STATE_FATAL 進程狀態(tài)由正在運行轉(zhuǎn)換為失敗
- PROCESS_STATE_UNKNOWN 未知的進程狀態(tài)
- REMOTE_COMMUNICATION 使用Supervisord的RPC接口與Supervisord進行通信
- PROCESS_LOG 進程產(chǎn)生日志輸出,包括標準輸出和標準錯誤輸出
- PROCESS_LOG_STDOUT 進程產(chǎn)生標準輸出
- PROCESS_LOG_STDERR 進程產(chǎn)生標準錯誤輸出
- PROCESS_COMMUNICATION 進程的日志輸出包含 和
- PROCESS_COMMUNICATION_STDOUT 進程的標準輸出包含 和
- PROCESS_COMMUNICATION_STDERR進程的標準錯誤輸出包含 和
- SUPERVISOR_STATE_CHANGE_RUNNING Supervisord 啟動
- SUPERVISOR_STATE_CHANGE_STOPPING Supervisord 停止
- TICK_5 每隔5秒觸發(fā)
- TICK_60 每隔60秒觸發(fā)
- TICK_3600 每隔3600觸發(fā)
- PROCESS_GROUP Supervisord的進程組發(fā)生變化
- PROCESS_GROUP_ADDED 新增了Supervisord的進程組
- PROCESS_GROUP_REMOVED 刪除了Supervisord的進程組
安裝superlance
也是python程序,直接pip 安裝
pip install superlance
superlance實戰(zhàn)
在實際配置supervisor使用superlance之前,首先要安裝sendmail,superlance使用這個命令行工具來發(fā)送email,利用各種包管理工具都可以簡單的安裝:
wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz tar zxvf sendEmail-v1.56.tar.gz cp sendEmail-v1.56/sendEmail /usr/bin/sendemail
發(fā)郵件測試一下
sendemail -f 發(fā)件人郵箱 -t 收件人郵箱 -s 發(fā)件人郵箱smtp服務器 -u "sendEmail" -m "haha" -xu 發(fā)件人郵箱 -xp 發(fā)件人郵箱密碼 -f 發(fā)件人 -t 收件人 -s 發(fā)件人smtp服務器 -u 主題 -m 內(nèi)容 -xu 發(fā)件人用戶名 -xp 發(fā)件人密碼
現(xiàn)在要做的就是配置一個supervisor配置文件,來一直監(jiān)聽進程的狀態(tài)變化
[eventlistener:crashmail] command=crashmail -a -s "sendemail -f dataalarm@wjoyxt.com -t alarm@wjoyxt.com -s smtp.mxhichina.com -u 'Process is crashed' -xu dataalarm@wjoyxt.com -xp Bigdata@2019@ -m >/dev/null 2>&1" -m alarm@wjoyxt.com events=PROCESS_STATE_EXITED redirect_stderr=false
或
[eventlistener:crashmail] command=crashmail -a -s "mail -s 'Process is crashed' alarm@wjoyxt.com" -m alarm@wjoyxt.com events=PROCESS_STATE_EXITED redirect_stderr=false
command參數(shù)中 -p 參數(shù)配置了crashmail只會對名為redis的監(jiān)控項作出響應,而 -m 參數(shù)中則配置了崩潰郵件會被發(fā)送到的地址,-a 監(jiān)控所有項
crashmail是一個主管“事件監(jiān)聽器”,用于訂閱PROCESS_STATE_EXITED事件。當crashmail 收到該事件并且轉(zhuǎn)換是"意外的(not expected)"時,crashmail 會將電子郵件通知發(fā)送到已配置的地址
events=PROCESS_STATE_EXITED,PROCESS_STATE_STOPPED,PROCESS_STATE_FATAL,PROCESS_LOG_STDERR 多個事件時,用逗號隔開
PROCESS_STATE_EXITED是在一個supervisor的監(jiān)控項對應的進程意外退出時會觸發(fā)的事件,這就使得一個進程出現(xiàn)意外退出的情況下會通知到crashmail。
crashmail.py [-p processname] [-a] [-o string] [-m mail_address] [-s sendmail]網(wǎng)址 選項: -p - 指定supervisor process_name。這個過程發(fā)送郵件 意外地轉(zhuǎn)換到EXITED狀態(tài)。如果這個過程是 組的一部分,可以使用 'process_name:group_name'語法。 -a - 當supervisord的任何孩子過渡時發(fā)送郵件 出人意料地意外地離開了EXITED狀態(tài)。覆蓋任何-p 在同一個crashmail進程調(diào)用中傳遞的參數(shù)。 -o - 指定用作郵件主題標題中前綴的參數(shù)。 -s - 用于發(fā)送電子郵件的sendmail命令 (例如“ / usr / sbin / sendmail - t - i ”)。必須是接受的命令 stdin上的頭和消息數(shù)據(jù)并發(fā)送郵件。默認是 “ / usr / sbin / sendmail - t - i ”。 -m - 指定電子郵件地址。該腳本將向此發(fā)送郵件 crashmail檢測到進程崩潰時的地址。如果沒有電子郵件 如果指定了地址,則不會發(fā)送電子郵件。 可以多次指定-p選項,允許 多個過程的規(guī)范。指定-a會覆蓋任何 選擇-p。 示例調(diào)用: crashmail.py -p program1 -p group1:program2 -m dev@example.com
添加好一個進程配置文件后
supervisorctl reload
重啟一下
整體示例代碼
[program:eacloud] command=/root/python/bin/uwsgi --ini uwsgi.ini ; 程序啟動命令 directory=/root/tyy autostart=true ; 在supervisord啟動的時候也自動啟動 startsecs=10 ; 啟動10秒后沒有異常退出,就表示進程正常啟動了,默認為1秒 autorestart=true ; 程序退出后自動重啟,可選值:[unexpected,true,false],默認為unexpected,表示進程意外殺死后才重啟 startretries=3 ; 啟動失敗自動重試次數(shù),默認是3 user=root ; 用哪個用戶啟動進程,默認是root priority=999 ; 進程啟動優(yōu)先級,默認999,值小的優(yōu)先啟動 redirect_stderr=true ; 把stderr重定向到stdout,默認false stdout_logfile_maxbytes=20MB ; stdout 日志文件大小,默認50MB stdout_logfile_backups = 20 ; stdout 日志文件備份數(shù),默認是10 ; stdout 日志文件,需要注意當指定目錄不存在時無法正常啟動,所以需要手動創(chuàng)建目錄(supervisord 會自動創(chuàng)建日志文件) stdout_logfile=/root/tyy/eacloud.log stopasgroup=false ;默認為false,進程被殺死時,是否向這個進程組發(fā)送stop信號,包括子進程 killasgroup=false ;默認為false,向進程組發(fā)送kill信號,包括子進程 [eventlistener:crashmail-exited] command=/root/python/bin/crashmail -p eacloud -m 1524701427@qq.com events=PROCESS_STATE redirect_stderr=false
到此這篇關于在python3中使用Supervisor的文章就介紹到這了,更多相關python使用Supervisor內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- python測試開發(fā)django之使用supervisord?后臺啟動celery?服務(worker/beat)
- 使用 Supervisor 監(jiān)控 Python3 進程方式
- Python supervisor強大的進程管理工具的使用
- python進程管理工具supervisor的安裝與使用教程
- 基于Python 的進程管理工具supervisor使用指南
- Python使用Supervisor來管理進程的方法
- python進程管理工具supervisor使用實例
- 使用Python的Supervisor進行進程監(jiān)控以及自動啟動
- python進程管理工具supervisor安裝使用
相關文章
pygame+opencv實現(xiàn)讀取視頻幀的方法示例
由于pygame.movie.Movie.play()只支持MPEG格式的視頻,所以決定使用與opencv讀取視頻幀的畫面,本文就詳細的介紹了pygame+opencv實現(xiàn)讀取視頻幀,感興趣的可以了解一下2021-12-12Django框架創(chuàng)建mysql連接與使用示例
這篇文章主要介紹了Django框架創(chuàng)建mysql連接與使用,簡單介紹了Linux環(huán)境下mysql的安裝,并結合實例形式分析了Django框架基于第三方庫pymysql連接mysql數(shù)據(jù)庫相關操作技巧,需要的朋友可以參考下2019-07-07python中matplotlib調(diào)整圖例位置的方法實例
在matplotlib中,一般圖例默認是在圖表內(nèi)部的,如果要放置到圖例外面,需要對坐標進行指定,下面這篇文章主要給大家介紹了關于python中matplotlib調(diào)整圖例位置的相關資料,需要的朋友可以參考下2022-06-06