温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

重启swoole的方法

发布时间:2021-01-08 16:35:33 来源:亿速云 阅读:258 作者:小新 栏目:编程语言

小编给大家分享一下重启swoole的方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

官方说是可以平滑重启所有的worker和tasker进程,可以通过

$swoole->reload(),或者\swoole_process::kill($master_pid, SIGUSR1),或者直接kill -USR1 master_pid等等。

简单测试

开启一个swoole_http_server,worker进程和tasker进程都为1个,然后浏览器发起一个http请求,请求的内容只是简单的sleep一下,通过sleep函数,应该是可以说明处理此请求的worker,是正在处于工作状态的吧,然后在sleep期间,进行reload操作。

当第一次发起一个请求到swoole server,manager进程会将请求调度到worker去进行处理,然后在worker处理的sleep期间,如果再有请求进来,manager是不会将后续的请求调度给唯一的worker进程,因为worker进程还在忙碌处理第一个请求。这个可以通过简单测试确认。

http请求就是路由到下面的简单方法。因为用的是easyswoole框架,执行php easyswoole reload all命令,其实也就是kill -USR1 master_pid。

Server的配置

$swoole_server->set([
    'worker_num' => 1,
    'task_worker_num' => 1,
    'reload_async' => true,
    'max

开始测试

1、任务逻辑写在worker进程里面

http方法

 public function test()
    {
        $start = microtime(true);
        echo '请求开始时间:' . $start . PHP_EOL;
        echo 'pid: ' . getmypid() . PHP_EOL;
        sleep(30);    # 这里睡眠脚本作测试
        echo 'finish sleep' . PHP_EOL;
        $end = microtime(true);
        echo '请求结束时间:' . $end . PHP_EOL;
        $this->writeJson(0, round(($end - $start), 3));
    }

监控onWorkerStart()方法

EventHelper::registerWithAdd(ServerManager::getInstance()->getMainEventRegister(),EventRegister::onWorkerStart,function (\swoole_server $server,$workerId){
     if(PHP_OS != 'Darwin'){
          $name = Config::getInstance()->getConf('SERVER_NAME');
           if( ($workerId < Config::getInstance()->getConf('MAIN_SERVER.SETTING.worker_num')) && $workerId >= 0){
                 $type = 'Worker';
              }else{
                 $type = 'TaskWorker';
              }
              cli_set_process_title("{$name}.{$type}.{$workerId}");
           }

          # 下面是打印测试的
          if ($type == 'Worker') {
              echo "这个是reload worker的时间:" . microtime(true) . "\n";
          }
          if ($type == 'TaskWorker') {
              echo "这个是reload TaskWorker的时间:" . microtime(true) . "\n";
          }
   });

测试结果:

请求开始时间:1566880257.9533    # 这里请求http接口,就是test()

pid: 42108

这个是reload TaskWorker的时间:1566880265.1501    # 这里是执行 php easyswoole reload all 的时间,因为tasker空闲没任务,就马上就行reload了。

这个是reload worker的时间:1566880275.1524    # 这个是worker的reload时间,因为在test()里面sleep(30),而且超过了max_wait_time,底层不会继续等待worker的任务完成,直接把旧的worker结束掉,结果也没有打印'finish sleep',创建了新的worker。

# 但是为什么是10s才重新创建worker呢?max_wait_time设置为5s啊??这个是我一直想不明白的。

看完了这篇文章,相信你对“重启swoole的方法”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI