您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

swoole怎么重启

2024/4/30 17:35:56发布11次查看
官方说是可以平滑重启所有的worker和tasker进程,可以通过
$swoole->reload(),或者\swoole_process::kill($master_pid, sigusr1),或者直接kill -usr1 master_pid等等。
推荐学习: swoole视频教程
简单测试
开启一个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怎么重启的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product