swoole重启是通过什么方法的,如何操作呢
Admin 2022-09-07 群英技术资讯 453 次浏览
官方说是可以平滑重启所有的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啊??这个是我一直想不明白的。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在thinkphp中,count方法是一个统计查询方法,用于统计数据表或者数据记录数,返回的结果就是统计的字符数,语法为“$model -> [where() -> ] count();”。
面向对象的三大特点是封装、继承、多态。本文将通过示例详细讲讲这三者的使用,文中示例代码讲解详细,需要的可以参考一下
PHP向它运行的任何脚本提供了大量的预定义常量。不过很多常量都是由不同的扩展库定义的,只有在加载了这些扩展库时才会出现,或者动态加载后,或者在编译时已经包括进去了...
本篇文章带大家带大家了解一下PHP7.X各版本(7.0、7.1、7.2、7.3、7.4)的新特性,有需要的可以看看,希望对大家有所帮助!
本篇文章小编给大家分享一下Python中的enum代码使用方法,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008