手记

SWOOLE 从入门到放弃之写个小框架(二十二)

补充一点关于服务进制监控的内容。

小伙伴们过去的项目中可能有这么一个需求,有些在线业务必须保证它一直在线,一般的操作就是利用Crontab来搞一个定时任务,有能力的同学可能还会用Python或Shell来写一个后台任务来循环操作,还有一些同学可会会直接用Supervisor。能实现它的手段有很多。

相比较之下,我还是建议小伙伴们用我们更熟悉的PHP来实现它。还是在我们的小框架基础上来实现它。

首先,我们的小框架它是完全可以脱离NGINX来提供HTTP服务的,但在运行的过程它就有可能在这样的问题,比如因为某些原因或错误导致swoole_http服务下线。而服务一旦停用或下线,就会严重影响在线用户的使用体验。老板也会发飙。。

SWOOLE 从入门到放弃之写个小框架(二十) 中,我们把base.php做了一个完善,然后又在启动文件start.php中写了启动调用入口。现阶段的base.php支持 start 启动、stop 停止、kill 杀死进程、restart重启和reload重载五个操作参数。

这就为了们今天要补充的监控工作提供了一个很好基础。接下来我们就开始写监控程序。我准备用 swoole_timer_tick来实现我们的监控工作。关于 swoole_timer_tick的说明请移步https://wiki.swoole.com/wiki/page/412.html。

接下来,我们要给它一些配置信息,比如轮循时间,发现下线后,是否重启任务等等。修改config/app.php,增加以下内容

//监控配置
    'monitor'   =>  [
        'timer'     =>  3000 ,  //间隔3秒,单位毫秒
        'restart'   => 1 ,       //是否重启,1是,0否
    ] ,

以上配置信息只是简单的配置,小伙伴们可以自行增加新的内容。

我们要怎么判断http服务是否在线呢?还记得config/app.php里有一个port配置吗,对,就是我们监听的端口,我们用netstat命令来查看它是否在线。


root@localhost:/piz$ netstat -anp | grep 9501
tcp        0      0 0.0.0.0:9501            0.0.0.0:*               LISTEN      8825/server-master  

可以看到,9501端口已经被监听,也就是说我们的框架正在运行。也证明我们用netstat命令它是可行的,接下来我们改一下它。

root@localhost:/piz$ netstat -anp | grep 9501 | grep LISTEN | wc -l
1

这样就能统计出进程数。接下来创建/monitor.php ,代码如下

#!/usr/bin/env php
<?php
require_once "./frame/base.php";

swoole_timer_tick(\Piz\Config::get_instance ()->get('app.monitor.timer'),function ($timer_id){
    $port = \Piz\Config::get_instance ()->get('app.port');
    $restart = \Piz\Config::get_instance ()->get('app.monitor.restart');
    $sh = "netstat -anp 2>/dev/null | grep {$port} | grep LISTEN | wc -l  ";
    $res = intval(shell_exec($sh));
    if(empty($res)){
        echo date('Y-m-d H:i:s'),"\t","服务下线",PHP_EOL;
        if($restart){
            echo shell_exec('php start.php start');
        }
    }
});

php monitor.php试运行一下,然后新开一个窗口把框架进程停掉,看下效果

1
root@localhost:/piz$ php monitor.php 
2018-04-18 15:52:47     服务下线
server 启动成功

OK,成功了。

1人推荐
随时随地看视频
慕课网APP