
%ign%ignore_a_1%re_a_1%如何处理高并发
①Reactor模型介绍 (推荐学习: swoole视频教程)
IO复用异步非阻塞程序使用经典的Reactor模型,Reactor顾名思义就是反应堆的意思,它本身不处理任何数据收发。只是可以监视一个socket(也可以是管道、eventfd、信号)句柄的事件变化。
Reactor只是一个事件发生器,实际对socket句柄的操作,如connect/accept、send/recv、close是在callback中完成的。
②swoole的架构
swoole采用多线程Reactor+多进程Worker。
当请求到达时,swoole是这样处理的:
请求到达 Main Reactor | |Main Reactor根据Reactor的情况,将请求注册给对应的Reactor(每个Reactor都有epoll。用来监听客户端的变化) | |客户端有变化时,交给worker来处理 | |worker处理完毕,通过进程间通信(比如管道、共享内存、消息队列)发给对应的reactor。 | |reactor将响应结果发给相应的连接 | | 请求处理完成
因为reactor基于epoll,所以每个reactor可以处理无数个连接请求。 如此,swoole就轻松的处理了高并发。
以上就是Swoole如何处理高并发的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/102762.html
微信扫一扫
支付宝扫一扫