温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

swoole如何运行

发布时间:2021-01-08 16:44:07 来源:亿速云 阅读:186 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关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等操作

感谢各位的阅读!关于“swoole如何运行”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI