supervisor的配置浅析

96
michaelgbw
2017.01.25 21:40* 字数 647

文/michael

前言

Linux的后台进程运行有好几种方法,例如nohup,screen等。但是一个进程有时会内存泄漏或者OOM等问题,如果是一个服务程序,要可靠地在后台运行,我们就需要把它做成daemon,最好还能监控进程状态,在意外结束时能自动重启。这时我们就产生了一种需求,能不能有个框架来完成呢。

supervisor

supervisor就是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。

#ubantu下的安装,当然这之前我们先确定安装了python
sudo apt-get install supervisor  
#我们也可以通过pip或着easy_install(python自带的,类似PHP的composer)
 pip search supervisor

apt-get/yum安装的会自动生成/etc/init.d/supervisord 和 /etc/supervisord.conf
如果是pip 安装的话,则麻烦点需要手动生成以上两者,好处是版本较新,生成配置文件:echo_supervisord_conf >/etc/supervisord.conf

我们先写了个简单的PHP程序,

<?php
for($i=0;$i<1000;$i++){
echo $i."\n";
sleep(1);

}

导入配置文件

echo_supervisord_conf > /etc/supervisord.conf

在/etc/supervisord.conf后面按需加入配置



我们看看进程

ps aux | grep php

然后我们开始开启supervisor

supervisord

记住哈,直接killsupervisord的进程是不行的,重新改写配置文件时要supervisorctl reload

supervisord,初始启动Supervisord,启动、管理配置中设置的进程。
supervisorctl stop programxxx,停止某一个进程(programxxx),programxxx为[program:blogdemon]里配置的值,这个示例就是blogdemon。
supervisorctl start programxxx,启动某个进程
supervisorctl restart programxxx,重启某个进程
supervisorctl stop all,停止全部进程,注:start、restart、stop都不会载入最新的配置文件。
supervisorctl reload,载入最新的配置文件,并按新的配置启动、管理所有进程。


这次可以看到php的脚本在进行

我们再改下php文件

<?php

for($i=0;$i<100;$i++){
echo $i."\n";
sleep(1);
$randnum = rand(0,100);
if($randnum > 50 ){
    exit;
}

}

我们再看看效果:


可以看到被exit的php进程都被重新唤起了,主要是因为这个参数autorestart=true

但说一点哈,我们的进程不能太短,就是执行时间太短会出现这样的错误:


有时我们不想让进程不停的跑,就是正常退出就关闭,怎么办,好办,我们把autorestart 改为false,我们再测试下一开始的代码:

<?php

for($i=0;$i<100;$i++){
echo $i."\n";
sleep(1);
$randnum = rand(0,100);
if($randnum > 50 ){
      exit(0);
}

}

重点来了哈~


2017-01-25 21:28:39屏幕截图.png

这是来自官网的截图,看懂了吧,这次我们更改配置

autorestart=unexpected
exitcodes=0

我们再试下:


这次正常退出了,但kill -9 就会重启~很神奇吧

拓展

supervise还有很多其他功能:

  • web页面监控
  • 配置用户名密码
  • 开机自起
  • 脚本输入输出重定向
    等等。。。。
    希望我们共同讨论下(当然看官网是很不错的学习途径)

结语

其实我们刚参加工作的时候,大多是ETL,不算正真意义的大数据工程师,慢慢的工作年限上去了,共同成长吧~先从小功能做起哈