0

0

Swoole基础Reactor模式_Swoole反应器概念教程【教程】

絕刀狂花

絕刀狂花

发布时间:2026-03-12 22:45:29

|

480人浏览过

|

来源于php中文网

原创

Reactor是纯C实现的异步网络事件分发器,只负责监听socket状态、分发就绪事件给Worker、维护心跳,不执行PHP代码或业务逻辑。

swoole基础reactor模式_swoole反应器概念教程【教程】

Reactor 不是 PHP 代码执行层,它是纯 C 实现的异步网络事件分发器——你写的 onConnectonReceive 回调根本不会在这里运行。

Reactor 是谁在干活?

它不解析 HTTP、不执行业务逻辑、不调用你的 PHP 函数。它只干三件事:监听 socket 是否可读/可写/出错、把就绪的连接或数据包交给 Worker 进程、定期踢掉空闲连接(靠 heartbeat_intervaltimewheel)。整个过程不涉及任何 PHP 用户态代码,全是底层 epoll/kqueue/select 的封装。

常见错误现象:strace -p $pid 看到大量 epoll_wait 调用但 CPU 却不高;top 显示 reactor_thread 占用极低,而 worker_proc 吃满 CPU——这说明瓶颈不在 Reactor,别瞎调 max_connectionreactor_num

  • Reactor 线程默认和 CPU 核心数一致(reactor_num = cpu_num),改多没用,改少会排队阻塞
  • 它不处理请求内容,所以 dispatch_mode = 2(FD 取模)下,同一个 TCP 连接的数据永远进同一个 Worker,但 Reactor 自己并不维护这个映射关系——那是调度策略,不是 Reactor 职责
  • 如果你在 onReceive 里做 sleep 或 file_get_contents,Worker 卡住,Reactor 依然飞快收包,只是包全堆在内核缓冲区或 Swoole 的 socket_array 里,最终触发 buffer_output_size 限制断连

怎么知道 Reactor 正在被拖慢?

reactor->event_numreactor->max_event_num 的比值,以及 reactor->timeout_msec 是否频繁触发。Swoole 本身不暴露这些字段,但你可以通过 swoole_server->stats()connection_numaccept_count 差值间接判断积压程度。

使用场景:压测时 accept_count 增速远低于连接建立速率,同时 connection_num 长期卡在某个值不上升,大概率是 Reactor 接受新连接变慢——检查是否触发了 EMFILE(文件描述符耗尽),或 disable_accept = 1 已被置位。

  • 不要依赖 ulimit -n 输出值,Swoole 启动时会调 getrlimit 获取真实 soft limit,若没显式调 setrlimit,可能只有 1024
  • reactor_num 设太高反而降低性能:线程切换开销上升,且多个 Reactor 线程争抢同一个 listen socket 的 accept 队列(Linux 内核 5.10+ 才支持 SO_REUSEPORT 多队列分流)
  • 观察 /proc/$pid/fd/ 下 fd 数量,如果接近 max_connectionconnection_num 很低,说明大量连接卡在三次握手完成前,可能是 SYN queue 溢出(需调 net.ipv4.tcp_max_syn_backlog

dispatch_mode 怎么选才不翻车?

这不是 Reactor 的配置项,而是 Master 进程协调 Reactor 与 Worker 之间投递策略的开关。选错会导致连接状态丢失、session 错乱、负载不均,但 Reactor 本身完全无感。

Tago AI
Tago AI

AI生成带货视频,专为电商卖货而生

下载

参数差异:

  • dispatch_mode = 1(轮询):最公平,但无法保证同个 TCP 连续包进同一 Worker,不适合需要长连接上下文的场景
  • dispatch_mode = 2(FD 取模):简单高效,但客户端用连接池复用少量连接时,90% 请求只打到少数几个 Worker,其他 Worker 闲置
  • dispatch_mode = 3(忙闲分配):实际负载更均衡,但连接归属随机,server->connections 在不同 Worker 里不可见,必须用 Redis 存 session
  • dispatch_mode = 4(IP 取模):适合 Web 场景,但 NAT 网关后所有用户 IP 相同,直接失效

性能影响:模式 2/4/5 用取模运算,几乎零开销;模式 3 需遍历 Worker 状态数组找空闲进程,Worker 数 > 32 时有轻微延迟;模式 1 最简单,但网络栈局部性差,cache miss 更多。

为什么改了 reactor_num 没效果?

因为 Swoole 默认启用多线程 Reactor,但你启动的是 Swoole\Http\ServerSwoole\WebSocket\Server,它们内部强制将 reactor_num 限制为 1——除非你显式调用 $server->set(['reactor_num' => 4]) 并确保未启用 task_worker(否则 Manager 进程会忽略该设置)。

容易踩的坑:

  • PHP-FPM 用户容易误以为 “Reactor = nginx”,其实 Reactor 更像 libevent + epoll 封装,而 Worker 才对应 php-fpm 子进程
  • onStart 里打印 posix_getpid()posix_getppid(),你会发现 Reactor 线程没有独立 PID,它和 Master 进程共享 PID,只是 Linux 的 LWP(轻量级进程)
  • 想调试 Reactor 行为?别 echo,别 var_dump,它们会阻塞整个线程。用 swoole_trace_loggdb -p $pid -ex 'thread apply all bt' -ex quit 看线程栈

真正关键的不是 Reactor 多不多,而是它转给 Worker 的数据包是否干净、及时、不粘包——这取决于你有没有正确设置 open_tcp_nodelaypackage_max_length 和协议解析逻辑,而不是 Reactor 本身。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

246

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

693

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3618

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

54

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

72

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
swoole进程树解析
swoole进程树解析

共4课时 | 0.2万人学习

Swoole系列-从0到1-新手进阶
Swoole系列-从0到1-新手进阶

共29课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号