免費web服務器網站:linux服務器批量管理工具

Supervisor安裝與配置(linux/unix進程管理工具) Supervisor(http://supervisord.org)是用Python開發的一個client/server服務,是Linux/Unix系統下的一個進程管理工具,不支持Windows系統。它可以很方便的監聽、啟動、停止、重啟一個或多個進程。用Supervisor管理的進程,當一個進程意外被殺死,supervisort監聽到進程死後,會自動將它重新拉起,很方便的做到進程自動恢復的功能,不再需要自己寫shell腳本來控制。

因為Supervisor是Python開發的,安裝前先檢查一下系統否安裝了Python2.4以上版本。下面以CentOS7.6,Python2.7.5版本環境下,介紹Supervisor的安裝與配置步聚:

實驗環境

系統平台

cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core)

Python版本

python -V
Python 2.7.5
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包裡帶的一個命令,使用easy_install實際上是在調用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 supervisorsuperviso命令

supervisor命令

supervisor安裝完成後會生成三個執行程序:supervisortd、supervisorctl、echo_supervisord_conf:

•supervisortd:用於管理supervisor本身服務•supervisorctl:用於管理我們需要委託給superviso工具的服務•echo_supervisord_conf:用於生成superviso的配置文件•supervisor的守護進程服務(用於接收進程管理命令)•客戶端(用於和守護進程通信,發送管理進程的指令)

[root@Jumpserver /]# which supervisord
/bin/supervisord
[root@Jumpserver /]# which supervisorctl
/bin/supervisorctl
[root@Jumpserver /]# which echo_supervisord_conf
/bin/echo_supervisord_conf

配置Supervisor

通過運行echo_supervisord_conf程序生成supervisor的初始化配置文件

如果使用yum安裝則此步驟省略,直接進行修改配置文件步驟

mkdir /etc/supervisord.d
echo_supervisord_conf > /etc/supervisord.conf

修改配置文件

supervisor的配置文件內容有很多,不過好多都不需要修改就行使用,我這裡只修改了以下兩項

#修改socket文件的mode,默認是0700
sed -i 's/;chmod=0700/chmod=0766/g' /etc/supervisord.conf   

#在配置文件最後添加以下兩行內容來包含/etc/supervisord目錄
sed -i '$a [include] \
files = /etc/supervisord.d/*.conf' /etc/supervisord.conf

編寫需要被Supervisor管理的進程

Supervisor只能管理非dameon進程,像默認的redis為前台運行、Tomcat其實是 startup.sh shutdown.sh來調用catalina.sh進行後台運行的,默認catalina.sh為前台運行的程序,不能管理像Nginx一樣的非dameon進程

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

想要我們的應用被Supervisor管理,就需要在/etc/supervisord目錄下編寫配置文件,Tomcat案例如下:

vim /etc/supervisord.d/tomcat.conf
[program:tomcat]                                        #程序唯一名稱
directory=/usr/local/tomcat                             #程序路徑
command=/usr/local/tomcat/bin/catalina.sh run           #運行程序的命令
autostart=true                                          #是否在supervisord啟動後tomcat也啟動
startsecs=10                                            #啟動10秒後沒有異常退出,就表示進程正常啟動了,默認為1秒
autorestart=true                                        #程序退出後自動重啟,可選值:[unexpected,true,false],默認為unexpected,表示進程意外殺死後才重啟;意思為如果不是supervisord來關閉的該進程則認為不正當關閉,supervisord會再次把該進程給啟動起來,只能使用該supervisorctl來進行關閉、啟動、重啟操作 
startretries=3                                          #啟動失敗自動重試次數,默認是3
user=root                                               #用哪個用戶啟動進程,默認是root
priority=999                                            #進程啟動優先級,默認999,假如Supervisord需要管理多個進程,那麼值小的優先啟動
stopsignal=INT
redirect_stderr=true                                    #把stderr重定向到stdout標準輸出,默認false
stdout_logfile_maxbytes=200MB                           #stdout標準輸出日誌文件大小,日誌文件大小到200M後則進行切割,切割後的日誌文件會標示為catalina.out1,catalina.out2,catalina.out3...,默認50MB
stdout_logfile_backups = 100                            #stdout標準輸出日誌文件備份數,保存100個200MB的日誌文件,超過100個後老的將被刪除,默認為10保存10個
stdout_logfile=/usr/local/tomcat/logs/catalina.out      #標準日誌輸出位置,如果輸出位置不存在則會啟動失敗
stopasgroup=false                                       #默認為false,進程被殺死時,是否向這個進程組發送stop信號,包括子進程
killasgroup=false                                       #默認為false,向進程組發送kill信號,包括子進程

啟動進程 使用supervisord管理啟動後,當你使用
/usr/local/tomcat/shutdown.sh或者kill $PID的時候,supervisord都會認為是意外關閉,會自動再次把進程拉起,除非是使用supervisord命令關閉

#supervisord啟動
supervisord -c /etc/supervisord.conf                    #啟動supervisord進程,我們在配置文件中設置了 autostart=true 參數,在supervisord啟動的時候 tomcat也隨之啟動
ps -ef|grep java 

程序管理

supervisorctl status tomcat                             #tomcat狀態
supervisorctl stop tomcat                               #停止tomcat
supervisorctl start tomcat                              #啟動tomcat
supervisorctl restart tomcat                            #重啟tomcat
supervisorctl reoload tomcat                            #重仔tomcat

Redis被Supervisor管理

redis默認不在配置文件中添加 daemonize yes 參數則是前台啟動的,所以也可以被我們的的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 900 1
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啟動redis

#關閉tomcat
supervisorctl stop tomcat
tomcat: stopped

#殺掉supervisord
ps -ef|grep supervisord
root     26927     1  0 10:47 ?        00:00:00 /usr/bin/python /bin/supervisord -c /etc/supervisord.conf
root     27549 27402  0 11:07 pts/2    00:00:00 grep --color=auto super
kill -9 26927

#重新啟動supervisord使其重新加載配置文件,supervisord默認會把redis和tomcat都拉起來
supervisord -c /etc/supervisord.conf

程序管理

supervisorctl status redis                              #redis狀態
supervisorctl stop redis                                #停止redis
supervisorctl start redis                               #啟動redis
supervisorctl restart reids                             #重啟redis
supervisorctl reoload redis                             #重載redis

程序管理

程序管理

supervisorctl status all                            #查看所有進程狀態
supervisorctl stop   all                            #停止所有進程
supervisorctl start  all                            #啟動所有進程
supervisorctl restart all                           #重啟所有進程
supervisorctl reoload all                           #重載所有進程

Supervisord開啟啟動配置

vim /usr/lib/systemd/system/supervisord.service
[Unit]
Description=Process Monitoring and Control Daemon
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

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/217489.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-09 00:27
下一篇 2024-12-09 00:27

相關推薦

發表回復

登錄後才能評論