Linux進(jìn)程管理工具Supervisor詳解
Supervisor安裝與配置(linux/unix進(jìn)程管理工具) Supervisor(http://supervisord.org)是用Python開發(fā)的一個(gè)client/server服務(wù),是Linux/Unix系統(tǒng)下的一個(gè)進(jìn)程管理工具,不支持Windows系統(tǒng)。它可以很方便的監(jiān)聽、啟動(dòng)、停止、重啟一個(gè)或多個(gè)進(jìn)程。用Supervisor管理的進(jìn)程,當(dāng)一個(gè)進(jìn)程意外被殺死,supervisort監(jiān)聽到進(jìn)程死后,會(huì)自動(dòng)將它重新拉起,很方便的做到進(jìn)程自動(dòng)恢復(fù)的功能,不再需要自己寫shell腳本來控制。
因?yàn)镾upervisor是Python開發(fā)的,安裝前先檢查一下系統(tǒng)否安裝了Python2.4以上版本。下面以CentOS7.6,Python2.7.5版本環(huán)境下,介紹Supervisor的安裝與配置步聚:
實(shí)驗(yàn)環(huán)境
系統(tǒng)平臺(tái)
- cat /etc/redhat-release
- CentOSLinux release 7.6.1810(Core)
Python版本
- python -V
- Python2.7.5
如果python版本低于2.6請(qǐng)升級(jí),下面貼出一個(gè)安裝python3.6.8的安裝示例
- yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel -y libffi-devel
- wget https://www.python.org/ftp/python/3.6.8/Python-3.6.8.tar.xz
- tar xf Python-3.6.8.tar.xz
- cd Python-3.6.8
- ./configure --prefix=/usr/local/python368
- make && make install
- echo 'export PATH=/usr/local/python368/bin:$PATH'>>/etc/profile
- source /etc/profile
- python3 -V
安裝 Supervisor
安裝 Supervisor的方法很多,以下介紹三種,我這里所采用的為第三種
1、easy_install 安裝 supervisor
安裝Python包管理工具(easy_install) easy_install是setuptools包里帶的一個(gè)命令,使用easy_install實(shí)際上是在調(diào)用setuptools來完成安裝模塊的工作,所以安裝setuptools即可:
- wget https://pypi.io/packages/source/s/setuptools/setuptools-33.1.1.zip
- unzip setuptools-33.1.1.zip
- cd setuptools-33.1.1
- python setup.py install
- easy_install supervisor
2、pip 安裝 supervisor
使用 pip 來安裝,前提要保證pip版本大于2.6
- pip install supervisor
3、yum epel-release 安裝 supervisor
- yum install -y epel-release && yum install -y supervisor
superviso命令
supervisor安裝完成后會(huì)生成三個(gè)執(zhí)行程序:supervisortd、supervisorctl、echo_supervisord_conf:
•supervisortd:用于管理supervisor本身服務(wù)•supervisorctl:用于管理我們需要委托給superviso工具的服務(wù)•echo_supervisord_conf:用于生成superviso的配置文件•supervisor的守護(hù)進(jìn)程服務(wù)(用于接收進(jìn)程管理命令)•客戶端(用于和守護(hù)進(jìn)程通信,發(fā)送管理進(jìn)程的指令)
- [root@Jumpserver /]# which supervisord
- /bin/supervisord
- [root@Jumpserver /]# which supervisorctl
- /bin/supervisorctl
- [root@Jumpserver /]# which echo_supervisord_conf
- /bin/echo_supervisord_conf
配置Supervisor
通過運(yùn)行echo_supervisord_conf程序生成supervisor的初始化配置文件
如果使用yum安裝則此步驟省略,直接進(jìn)行修改配置文件步驟
- mkdir /etc/supervisord.d
- echo_supervisord_conf >/etc/supervisord.conf
修改配置文件
supervisor的配置文件內(nèi)容有很多,不過好多都不需要修改就行使用,我這里只修改了以下兩項(xiàng)
- #修改socket文件的mode,默認(rèn)是0700
- sed -i 's/;chmod=0700/chmod=0766/g'/etc/supervisord.conf
- #在配置文件最后添加以下兩行內(nèi)容來包含/etc/supervisord目錄
- sed -i '$a [include] \
- files =/etc/supervisord.d/*.conf' /etc/supervisord.conf
編寫需要被Supervisor管理的進(jìn)程
Supervisor只能管理非dameon進(jìn)程,像默認(rèn)的redis為前臺(tái)運(yùn)行、Tomcat其實(shí)是 startup.sh shutdown.sh來調(diào)用catalina.sh進(jìn)行后臺(tái)運(yùn)行的,默認(rèn)catalina.sh為前臺(tái)運(yùn)行的程序,不能管理像Nginx一樣的非dameon進(jìn)程
Tomcat被Supervisor管理
Tomcat安裝如下:
- wget http://us.mirrors.quenda.co/apache/tomcat/tomcat-8/v8.5.47/bin/apache-tomcat-8.5.47.tar.gz
- yum install java-1.8.0-openjdk.x86_64 java-1.8.0-openjdk-devel.x86_64 -y
- tar xf apache-tomcat-8.5.47.tar.gz -C /usr/local/
- mv /usr/local/apache-tomcat-8.5.47/usr/local/tomcat
想要我們的應(yīng)用被Supervisor管理,就需要在/etc/supervisord目錄下編寫配置文件,Tomcat案例如下:
- vim /etc/supervisord.d/tomcat.conf
- [program:tomcat]#程序唯一名稱
- directory=/usr/local/tomcat #程序路徑
- command=/usr/local/tomcat/bin/catalina.sh run #運(yùn)行程序的命令
- autostart=true#是否在supervisord啟動(dòng)后tomcat也啟動(dòng)
- startsecs=10#啟動(dòng)10秒后沒有異常退出,就表示進(jìn)程正常啟動(dòng)了,默認(rèn)為1秒
- autorestart=true#程序退出后自動(dòng)重啟,可選值:[unexpected,true,false],默認(rèn)為unexpected,表示進(jìn)程意外殺死后才重啟;意思為如果不是supervisord來關(guān)閉的該進(jìn)程則認(rèn)為不正當(dāng)關(guān)閉,supervisord會(huì)再次把該進(jìn)程給啟動(dòng)起來,只能使用該supervisorctl來進(jìn)行關(guān)閉、啟動(dòng)、重啟操作
- startretries=3#啟動(dòng)失敗自動(dòng)重試次數(shù),默認(rèn)是3
- user=root #用哪個(gè)用戶啟動(dòng)進(jìn)程,默認(rèn)是root
- priority=999#進(jìn)程啟動(dòng)優(yōu)先級(jí),默認(rèn)999,假如Supervisord需要管理多個(gè)進(jìn)程,那么值小的優(yōu)先啟動(dòng)
- stopsignal=INT
- redirect_stderr=true#把stderr重定向到stdout標(biāo)準(zhǔn)輸出,默認(rèn)false
- stdout_logfile_maxbytes=200MB#stdout標(biāo)準(zhǔn)輸出日志文件大小,日志文件大小到200M后則進(jìn)行切割,切割后的日志文件會(huì)標(biāo)示為catalina.out1,catalina.out2,catalina.out3...,默認(rèn)50MB
- stdout_logfile_backups =100#stdout標(biāo)準(zhǔn)輸出日志文件備份數(shù),保存100個(gè)200MB的日志文件,超過100個(gè)后老的將被刪除,默認(rèn)為10保存10個(gè)
- stdout_logfile=/usr/local/tomcat/logs/catalina.out#標(biāo)準(zhǔn)日志輸出位置,如果輸出位置不存在則會(huì)啟動(dòng)失敗
- 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)程
啟動(dòng)進(jìn)程 使用supervisord管理啟動(dòng)后,當(dāng)你使用/usr/local/tomcat/shutdown.sh或者kill $PID的時(shí)候,supervisord都會(huì)認(rèn)為是意外關(guān)閉,會(huì)自動(dòng)再次把進(jìn)程拉起,除非是使用supervisord命令關(guān)閉
- #supervisord啟動(dòng)
- supervisord -c /etc/supervisord.conf #啟動(dòng)supervisord進(jìn)程,我們?cè)谂渲梦募性O(shè)置了 autostart=true 參數(shù),在supervisord啟動(dòng)的時(shí)候 tomcat也隨之啟動(dòng)
- ps -ef|grep java #查看tomcat是否啟動(dòng)
程序管理
- supervisorctl status tomcat #tomcat狀態(tài)
- supervisorctl stop tomcat #停止tomcat
- supervisorctl start tomcat #啟動(dòng)tomcat
- supervisorctl restart tomcat #重啟tomcat
- supervisorctl reoload tomcat #重仔tomcat
Redis被Supervisor管理
redis默認(rèn)不在配置文件中添加 daemonize yes 參數(shù)則是前臺(tái)啟動(dòng)的,所以也可以被我們的的Supervisor所管理 redis配置文件如下:
- cat redis6001.conf
- port 6001
- bind 192.168.31.230
- protected-mode yes
- pidfile "/usr/local/redis/run/redis6001.pid"
- loglevel notice
- logfile "/usr/local/redis/logs/redis6001.log"
- save 9001
- stop-writes-on-bgsave-error yes
- rdbcompression yes
- rdbchecksum yes
- dbfilename dump.rdb
- dir "/usr/local/redis/data/rdb/"
- timeout 0
- tcp-keepalive 300
編寫redis被Supervisor管理的案例
- vim /etc/supervisord.d/redis.conf
- [program:redis]
- directory=/usr/local/redis
- command=/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis6001.conf
- autostart=true
- startsecs=10
- autorestart=true
- startretries=3
- user=root
- priority=999
- stopsignal=INT
- redirect_stderr=true
- stdout_logfile_maxbytes=200MB
- stdout_logfile_backups =100
- stdout_logfile=/usr/local/redis/logs/redis6001.log
- stopasgroup=false
- killasgroup=false
使用super啟動(dòng)redis
- #關(guān)閉tomcat
- supervisorctl stop tomcat
- tomcat: stopped
- #殺掉supervisord
- ps -ef|grep supervisord
- root 269271010:47?00:00:00/usr/bin/python /bin/supervisord -c /etc/supervisord.conf
- root 2754927402011:07 pts/200:00:00 grep --color=autosuper
- kill -926927
- #重新啟動(dòng)supervisord使其重新加載配置文件,supervisord默認(rèn)會(huì)把redis和tomcat都拉起來
- supervisord -c /etc/supervisord.conf
程序管理
- supervisorctl status redis #redis狀態(tài)
- supervisorctl stop redis #停止redis
- supervisorctl start redis #啟動(dòng)redis
- supervisorctl restart reids #重啟redis
- supervisorctl reoload redis #重載redis
程序管理
程序管理
- supervisorctl status all #查看所有進(jìn)程狀態(tài)
- supervisorctl stop all #停止所有進(jìn)程
- supervisorctl start all #啟動(dòng)所有進(jìn)程
- supervisorctl restart all #重啟所有進(jìn)程
- supervisorctl reoload all #重載所有進(jìn)程
Supervisord開啟啟動(dòng)配置
- vim /usr/lib/systemd/system/supervisord.service
- [Unit]
- Description=ProcessMonitoringandControlDaemon
- After=rc-local.service nss-user-lookup.target
- [Service]
- Type=forking
- ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf
- [Install]
- WantedBy=multi-user.target
- systemctl enable supervisord
- systemctl is-enabled supervisord