woole线程包括哪一些,概念分别是什么
Admin 2022-07-21 群英技术资讯 425 次浏览
swoole中的线程:
1、MainReactor(主线程)
主线程会负责监听server socket,如果有新的连接accept,主线程会评估每个Reactor线程的连接数量。将此连接分配给连接数最少的reactor线程,做一个负载均衡。
2 、Reactor线程组
Reactor线程负责维护客户端机器的TCP连接、处理网络IO、收发数据完全是异步非阻塞的模式。
swoole的主线程在Accept新的连接后,会将这个连接分配给一个固定的Reactor线程,在socket可读时读取数据,并进行协议解析,将请求投递到Worker进程。在socket可写时将数据发送给TCP客户端。
3、心跳包检测线程(HeartbeatCheck)
Swoole配置了心跳检测之后,心跳包线程会在固定时间内对所有之前在线的连接
发送检测数据包
4、UDP收包线程(UdpRecv)
接收并且处理客户端udp数据包
swoole想要实现最好的性能必须创建出多个工作进程帮助处理任务,但Worker进程就必须fork操作,但是fork操作是不安全的,如果没有管理会出现很多的僵尸进程,进而影响服务器性能,同时worker进程被误杀或者由于程序的原因会异常退出,为了保证服务的稳定性,需要重新创建worker进程。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文给大家我们来了解laravel关闭token的方法,实现laravel关闭token的方法有三种,操作都并不难,下文都有介绍,有需要的朋友可以参考,接下来我们就一起来看看。
PHP自动加载类的原理是什么?有些朋友对在PHP 5中类的自动加载的原理不是很清楚,因此这篇文章就给大家介绍一下PHP自动加载类的基本概念,原理以及用法等等,感兴趣的朋友可以看一下。
swoole客户端无法连接的解决办法:首先修改服务端代码,并注释掉“$serv->close($fd); ”的部分;然后通过命令“yum install telnet -y”安装“telnet”;最后通过“telnet”即可恢复连接。
swoole和rabbitmq的区别:RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。Swoole是一个PHP的C扩展,可用来开发PHP的高性能高并发TCP/UDP Server。
本篇文章给大家介绍一下php7实现垃圾回收机制的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008