swoole运行模式有几种,分别有何优缺点
Admin 2022-08-30 群英技术资讯 839 次浏览
今天这篇给大家分享的知识是“swoole运行模式有几种,分别有何优缺点”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“swoole运行模式有几种,分别有何优缺点”文章能帮助大家解决问题。
swoole两种运行模式介绍:
单线程模式(SWOOLE_BASE)
这种模式就是传统的异步非阻塞Server。与Nginx和Node.js等程序是完全一致的。
在时间循环中直接回调PHP的函数,而不是dispatch投递任务。如果回调函数中有阻塞操作会导致Server退化为同步模式。worker_num参数对与BASE模式仍然有效,会启动多个Worker进程。
BASE模式下没有Master进程的角色
每个Worker进程同时承担了Process模式下Reactor线程和Worker进程两部分职责
BASE模式下Manager进程是可选的,当设置了worker_num=1,并且没有使用Task和MaxRequest特性时,底层将直接创建一个单独的Worker进程,不创建Manager进程
BASE模式的优点:
BASE模式没有IPC开销,性能更好
BASE模式代码更简单,不容易出错
BASE模式的缺点:
TCP连接是在Worker进程中维持的,所以当某个Worker进程挂掉时,此Worker内的所有连接都将被关闭
少量TCP长连接无法利用到所有Worker进程
TCP连接与Worker是绑定的,长连接应用中某些连接的数据量大,这些连接所在的Worker进程负载会非常高。但某些连接数据量小,所以在Worker进程的负载会非常低,不同的Worker进程无法实现均衡。
BASE模式的适用场景:
如果客户端连接之间不需要交互,可以使用BASE模式。如Memcache、Http服务器等。
进程模式(SWOOLE_PROCESS)
多进程模式是最复杂的方式,用了大量的进程间通信、进程管理机制。适合业务逻辑非常复杂的场景。Swoole提供了完善的进程管理、内存保护机制。 在业务逻辑非常复杂的情况下,也可以长期稳定运行。
Swoole在Reactor线程中提供了Buffer的功能,可以应对大量慢速连接和逐字节的恶意客户端。另外也提供了CPU亲和设置选项,使程序运行的效率更好。
进程模式的优点:
连接与数据请求发送是分离的,不会因为某些连接数据量大某些连接数据量小导致Worker进程不均衡
Worker进程发送致命错误时,连接并不会被切断
可实现单连接并发,仅保持少量TCP连接,请求可以并发地在多个Worker进程中处理
进程模式的缺点:
存在2次IPC的开销,master进程与worker进程需要使用UnixSocket进行通信
不支持某些高级功能,如sendwait、pause、resume等操作
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在laravel中,distinct()方法用于强制让查找返回不重复的结果,语法为“$users=DB::table('users')->distinct()->get();”;若使用想要查找多个字段,可指定select字段并添加字段名称。
用PHP实现微信授权登录的流程及方法是什么?要使用微信授权登录功能需要先在微信开发平台创建应用。然后会获取微信提供给你的appId和AppSecret,然后就可以进行开发了。当然现有很多大佬封装的微信类库非常齐全,而且还很好用,可以去试试,下面讲解一下基本实现方法。
特殊的NULL值表示一个变量没有值。NULL类型唯一可能的值就是NULL。在下列情况下一个变量被认为是NULL:被赋值为NULL。尚未被赋值。被unset()。语法NU...
这篇文章给大家分享的是有关php数组函数的内容,主要介绍array_push()、array_pop()及array_shift()对数组进行入栈,出栈及移除的操作,小编觉得挺实用的,因此分享给大家做个参考,感兴趣的朋友就继续往下看吧。
“tcp”与“udp”的区别是:1、TCP面向连接(如打电话要先拨号建立连接);UDP是无连接的,即发送数据之前不需要建立连接;2、TCP面向字节流,UDP是面向报文的;3、TCP的逻辑通信信道是全双工的可靠信道,UDP则是不可靠信道。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008