摘要:使用開(kāi)發(fā)的一個(gè)服務(wù),是系統(tǒng)下的一個(gè)進(jìn)程管理工具。一切就緒后,我們使用如下命令就可以啟動(dòng)隊(duì)列進(jìn)程的監(jiān)聽(tīng)了這里值得注意的是,如果處理隊(duì)列的代碼更改了,需要重啟的隊(duì)列管理才能生效。
supervisor使用python開(kāi)發(fā)的一個(gè)client/server服務(wù),是linux/unix系統(tǒng)下的一個(gè)進(jìn)程管理工具。它可以很方便的監(jiān)聽(tīng)、停止、重啟一個(gè)或多個(gè)進(jìn)程。用supervisor管理的進(jìn)程,打你個(gè)進(jìn)程意外被殺死,supervisor監(jiān)聽(tīng)到進(jìn)程死后,會(huì)自動(dòng)將它重新拉起,很方便的做到自動(dòng)恢復(fù)的功能,不再需要自己寫(xiě)shell腳本控制。安裝supervisor
sudo pip install supervisor 或者 easy_install supervisor
還有其他安裝方式,請(qǐng)參考官網(wǎng)
supervisor安裝完成后會(huì)生成三個(gè)執(zhí)行程序:
supervisord:守護(hù)進(jìn)程服務(wù)(用于接收進(jìn)程管理命令)
supervisorctl:客戶端(用于和守護(hù)進(jìn)程通信,發(fā)送管理進(jìn)程的指令)
echo_supervisord_conf:生成初始配置文件程序
配置運(yùn)行supervisord服務(wù)的時(shí)候,需要指定supervisor配置文件,如果沒(méi)有顯示指定,默認(rèn)在以下目錄查找:
/etc/supervisord.conf /etc/supervisor/supervisord.conf //默認(rèn)是沒(méi)有這些配置文件的
** 可以通過(guò)echo_supervisord_conf程序生成supervisor的初始化配置文件,如下所示:
mkdir /etc/supervisor echo_supervisord_conf > /etc/supervisor/supervisord.conf配置文件說(shuō)明
supervisor的配置參數(shù)較多,下面介紹一下常用的參數(shù)配置,詳細(xì)的配置及說(shuō)明,請(qǐng)參考官方文檔介紹。
[unix_http_server] file=/tmp/supervisor.sock ;UNIX socket 文件,supervisorctl 會(huì)使用 ;chmod=0700 ;socket文件的mode,默認(rèn)是0700 ;chown=nobody:nogroup ;socket文件的owner,格式:uid:gid ;[inet_http_server] ;HTTP服務(wù)器,提供web管理界面 ;port=127.0.0.1:9001 ;Web管理后臺(tái)運(yùn)行的IP和端口,如果開(kāi)放到公網(wǎng),需要注意安全性 ;username=user ;登錄管理后臺(tái)的用戶名 ;password=123 ;登錄管理后臺(tái)的密碼 [supervisord] logfile=/tmp/supervisord.log ;日志文件,默認(rèn)是 $CWD/supervisord.log logfile_maxbytes=50MB ;日志文件大小,超出會(huì)rotate,默認(rèn) 50MB,如果設(shè)成0,表示不限制大小 logfile_backups=10 ;日志文件保留備份數(shù)量默認(rèn)10,設(shè)為0表示不備份 loglevel=info ;日志級(jí)別,默認(rèn)info,其它: debug,warn,trace pidfile=/tmp/supervisord.pid ;pid 文件 nodaemon=false ;是否在前臺(tái)啟動(dòng),默認(rèn)是false,即以 daemon 的方式啟動(dòng) minfds=1024 ;可以打開(kāi)的文件描述符的最小值,默認(rèn) 1024 minprocs=200 ;可以打開(kāi)的進(jìn)程數(shù)的最小值,默認(rèn) 200 [supervisorctl] serverurl=unix:///tmp/supervisor.sock ;通過(guò)UNIX socket連接supervisord,路徑與unix_http_server部分的file一致 ;serverurl=http://127.0.0.1:9001 ; 通過(guò)HTTP的方式連接supervisord ; [program:xx]是被管理的進(jìn)程配置參數(shù),xx是進(jìn)程的名稱 [program:xx] command=/opt/apache-tomcat-8.0.35/bin/catalina.sh run ; 程序啟動(dòng)命令 autostart=true ; 在supervisord啟動(dòng)的時(shí)候也自動(dòng)啟動(dòng) startsecs=10 ; 啟動(dòng)10秒后沒(méi)有異常退出,就表示進(jìn)程正常啟動(dòng)了,默認(rèn)為1秒 autorestart=true ; 程序退出后自動(dòng)重啟,可選值:[unexpected,true,false],默認(rèn)為unexpected,表示進(jìn)程意外殺死后才重啟 startretries=3 ; 啟動(dòng)失敗自動(dòng)重試次數(shù),默認(rèn)是3 user=tomcat ; 用哪個(gè)用戶啟動(dòng)進(jìn)程,默認(rèn)是root priority=999 ; 進(jìn)程啟動(dòng)優(yōu)先級(jí),默認(rèn)999,值小的優(yōu)先啟動(dòng) redirect_stderr=true ; 把stderr重定向到stdout,默認(rèn)false stdout_logfile_maxbytes=20MB ; stdout 日志文件大小,默認(rèn)50MB stdout_logfile_backups = 20 ; stdout 日志文件備份數(shù),默認(rèn)是10 ; stdout 日志文件,需要注意當(dāng)指定目錄不存在時(shí)無(wú)法正常啟動(dòng),所以需要手動(dòng)創(chuàng)建目錄(supervisord 會(huì)自動(dòng)創(chuàng)建日志文件) stdout_logfile=/opt/apache-tomcat-8.0.35/logs/catalina.out stopasgroup=false ;默認(rèn)為false,進(jìn)程被殺死時(shí),是否向這個(gè)進(jìn)程組發(fā)送stop信號(hào),包括子進(jìn)程 killasgroup=false ;默認(rèn)為false,向進(jìn)程組發(fā)送kill信號(hào),包括子進(jìn)程 ;包含其它配置文件 [include] files = relative/directory/*.ini ;可以指定一個(gè)或多個(gè)以.ini結(jié)束的配置文件 include示例:配置管理進(jìn)程
進(jìn)程管理配置參數(shù),不建議全都寫(xiě)在supervisord.conf文件中,應(yīng)該每個(gè)進(jìn)程寫(xiě)一個(gè)配置文件放在include指定的目錄下包含進(jìn)supervisord.conf文件中。
打開(kāi)最后的include注釋:
[include] files=/etc/supervisor/conf.d/*.conf //新增的 Supervisor 配置文件放在 /etc/supervisor/conf.d/ 目錄下,并且以 conf 結(jié)尾。
這個(gè)時(shí)候就可以啟動(dòng)了服務(wù)了
supervisord -c /etc/supervisor/supervisord.conf使用supervisor 管理 laravel 隊(duì)列進(jìn)程
我們使用 Laravel 隊(duì)列,會(huì)用到 php artisan queue:work 命令,讓它監(jiān)聽(tīng)隊(duì)列,我們可以通過(guò) nohup 方式讓它在后臺(tái)運(yùn)行,但是進(jìn)程如果意外中斷是不會(huì)自動(dòng)重啟的,所以使用 Supervisor 來(lái)監(jiān)控進(jìn)程是個(gè)很好的方式。
首先在 /etc/supervisor/conf.d/ 目錄下新增一個(gè) Supervisor 的配置文件,如下:
[program:laravel-worker] process_name=%(program_name)s_%(process_num)02d command=php /www/artisan queue:work --tries=3 autostart=true autorestart=true user=nginx numprocs=8 redirect_stderr=true stdout_logfile=/var/log/supervisor/laravel-queue.log
這里 user 填寫(xiě)網(wǎng)站運(yùn)行進(jìn)程的用戶,如nginx,numprocs 表示啟動(dòng)多少個(gè)進(jìn)程來(lái)監(jiān)聽(tīng) Laravel 隊(duì)列。
一切就緒后,我們使用如下命令就可以啟動(dòng)隊(duì)列進(jìn)程的監(jiān)聽(tīng)了:
sudo supervisorctl reread sudo supervisorctl update sudo supervisorctl start laravel-worker:*
這里值得注意的是,如果 Laravel 處理隊(duì)列的代碼更改了,需要重啟 Supervisor 的隊(duì)列管理才能生效。web 管理界面
出于安全考慮,默認(rèn)配置是沒(méi)有開(kāi)啟web管理界面,需要修改supervisord.conf配置文件,打開(kāi)http訪權(quán)限:
[inet_http_server] ; inet (TCP) server disabled by default port=127.0.0.1:9001 ; (ip_address:port specifier, *:port for all iface) username=user ; (default is no username (open server)) password=123 ; (default is no password (open server)) port:綁定訪問(wèn)IP和端口,這里是綁定的是本地IP和9001端口 username:登錄管理后臺(tái)的用戶名
參考文章:
https://laravel-china.org/top...
http://www.linuxidc.com/Linux...
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/25607.html
摘要:導(dǎo)語(yǔ)代碼部分完成后,接下來(lái)是配置,用來(lái)進(jìn)程守護(hù)。當(dāng)隊(duì)列意外停止后,可以重啟進(jìn)程,保證隊(duì)列的穩(wěn)定運(yùn)行。參考資料配置安裝配置使用。 導(dǎo)語(yǔ) 代碼部分完成后,接下來(lái)是配置 Supervisor,用來(lái)進(jìn)程守護(hù)。當(dāng)隊(duì)列意外停止后,Supervisor 可以重啟進(jìn)程,保證隊(duì)列的穩(wěn)定運(yùn)行。 安裝以及配置 依次執(zhí)行 yum install python-setuptools、easy_install ...
摘要:前言是一個(gè)客戶端服務(wù)器系統(tǒng),允許其用戶在類操作系統(tǒng)上控制許多進(jìn)程。這將打印一個(gè)示例的配置文件到您的終端。不會(huì)自動(dòng)生成配置文件。具體可見(jiàn)官方文檔后臺(tái)提供的后臺(tái)管理比較簡(jiǎn)單大致功能有重啟啟動(dòng)停止進(jìn)程,打印日志,清除日志等。 showImg(https://segmentfault.com/img/bVbgXm1?w=242&h=45); 前言 Supervisor是一個(gè)客戶端/服務(wù)器系統(tǒng),...
摘要:如果服務(wù)器中該賬號(hào)的鑰匙對(duì)已經(jīng)存在,并且已經(jīng)將放到該賬號(hào)的設(shè)置中,可以跳過(guò)這一步。如果不符合,需要根據(jù)提示安裝必要的擴(kuò)展。后續(xù)再進(jìn)行補(bǔ)充做守護(hù)隊(duì)列監(jiān)聽(tīng)進(jìn)程和自動(dòng)部署到服務(wù)器的說(shuō)明。 系統(tǒng)LAMP基礎(chǔ)環(huán)境是已經(jīng)搭建好,記錄要將web項(xiàng)目部署到線上的過(guò)程如下,方便后續(xù)部署新項(xiàng)目時(shí)參考: laravel項(xiàng)目ubuntu 16.04php 7.0 克隆項(xiàng)目到服務(wù)器 (1)我們使用 your@e...
摘要:如果服務(wù)器中該賬號(hào)的鑰匙對(duì)已經(jīng)存在,并且已經(jīng)將放到該賬號(hào)的設(shè)置中,可以跳過(guò)這一步。如果不符合,需要根據(jù)提示安裝必要的擴(kuò)展。后續(xù)再進(jìn)行補(bǔ)充做守護(hù)隊(duì)列監(jiān)聽(tīng)進(jìn)程和自動(dòng)部署到服務(wù)器的說(shuō)明。 系統(tǒng)LAMP基礎(chǔ)環(huán)境是已經(jīng)搭建好,記錄要將web項(xiàng)目部署到線上的過(guò)程如下,方便后續(xù)部署新項(xiàng)目時(shí)參考: laravel項(xiàng)目ubuntu 16.04php 7.0 克隆項(xiàng)目到服務(wù)器 (1)我們使用 your@e...
閱讀 2587·2021-11-25 09:43
閱讀 1864·2021-09-22 15:26
閱讀 3742·2019-08-30 15:56
閱讀 1715·2019-08-30 15:55
閱讀 1900·2019-08-30 15:54
閱讀 817·2019-08-30 15:52
閱讀 3158·2019-08-29 16:23
閱讀 897·2019-08-29 12:43