侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

swoole怎么重启

php  /  管理员 发布于 6年前   345

官方说是可以平滑重启所有的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怎么重启的详细内容,更多请关注其它相关文章!


  • 上一条:
    swoole为什么不能代替nginx
    下一条:
    swoole如何常驻进程
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • AI Agent
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • opencode AI智能体自主规划开发游戏:王者荣耀模拟战游戏初体验!英雄角色开发中...(0个评论)
    • opencode AI智能体自主规划开发游戏:王者荣耀模拟战游戏初体验!(0个评论)
    • opencode + Oh-my-openagent,我的第一个免费的ai编程智能体管家:Sisyphus(0个评论)
    • Google AI Studio升级全栈 vibe coding体验,可直接构建带登录和数据库的应用(0个评论)
    • Apifox桌面端被曝遭供应链投毒:CDN 脚本被篡改,窃取 SSH 密钥与 Git 凭证(0个评论)
    • 在go语言中实现字符串可逆性压缩及解压缩功能(0个评论)
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 近期评论
    • test1 在

      opencode + Oh-my-openagent,我的第一个免费的ai编程智能体管家:Sisyphus中评论 test..
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • Zita 在

      Google AI Studio升级全栈 vibe coding体验,可直接构建带登录和数据库的应用中评论 111222..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客