× 警告!旧版文档已经暂停维护,请查看新版文档。点击前往新版文档

Server的两种运行模式介绍

单线程模式(SWOOLE_BASE

这种模式就是传统的异步非阻塞Server。与NginxNode.js等程序是完全一致的。

在时间循环中直接回调PHP的函数,而不是dispatch投递任务。如果回调函数中有阻塞操作会导致Server退化为同步模式。worker_num参数对与BASE模式仍然有效,会启动多个Worker进程。

  • BASE模式下没有Master进程的角色
  • 每个Worker进程同时承担了Process模式下Reactor线程和Worker进程两部分职责
  • BASE模式下Manager进程是可选的,当设置了worker_num=1,并且没有使用TaskMaxRequest特性时,底层将直接创建一个单独的Worker进程,不创建Manager进程

BASE模式的优点:

  • BASE模式没有IPC开销,性能更好
  • BASE模式代码更简单,不容易出错

BASE模式的缺点:

  • TCP连接是在Worker进程中维持的,所以当某个Worker进程挂掉时,此Worker内的所有连接都将被关闭
  • 少量TCP长连接无法利用到所有Worker进程
  • TCP连接与Worker是绑定的,长连接应用中某些连接的数据量大,这些连接所在的Worker进程负载会非常高。但某些连接数据量小,所以在Worker进程的负载会非常低,不同的Worker进程无法实现均衡。

BASE模式的适用场景:

如果客户端连接之间不需要交互,可以使用BASE模式。如MemcacheHttp服务器等。

进程模式(SWOOLE_PROCESS

多进程模式是最复杂的方式,用了大量的进程间通信、进程管理机制。适合业务逻辑非常复杂的场景。Swoole提供了完善的进程管理、内存保护机制。 在业务逻辑非常复杂的情况下,也可以长期稳定运行。

SwooleReactor线程中提供了Buffer的功能,可以应对大量慢速连接和逐字节的恶意客户端。另外也提供了CPU亲和设置选项,使程序运行的效率更好。

进程模式的优点:

  • 连接与数据请求发送是分离的,不会因为某些连接数据量大某些连接数据量小导致Worker进程不均衡
  • Worker进程发送致命错误时,连接并不会被切断
  • 可实现单连接并发,仅保持少量TCP连接,请求可以并发地在多个Worker进程中处理

进程模式的缺点:

  • 存在2IPC的开销,master进程与worker进程需要使用UnixSocket进行通信
  • 不支持某些高级功能,如sendwaitpauseresume等操作

  • 大鹏

    慢速连接和逐字节的恶意客户端,请问这是什么?

  • 王南

    http://wiki.swoole.com/wiki/page/p-buffer.html

  • mango_alex

    Reactor跟worker通信,会通过manager进程转发吗?还是直接通信?

  • 升天包子

    Reactor跟worker是直接通过IPC通信的,不会通过manager进程转发。manager只是管理worker进程的

  • 小鱼网络

    东西看似不错文档看不明白

  • 15513082138

    进程模式(SWOOLE_PROCESS)指的是运行一个server时产生多个进程(设置指定worker数),每个进程执行完之后才会处理新的请求吗?

  • 13147010548

    BASE模式 完全和Workerman架构一毛一样(除了多个task),Process模式和Gateway-worker的模式几乎一毛一样(只不过Swoole的主进里将Connection路由到了Reactor线程,本质上主线程还是持有所有Connection),但是Gateway-worker的分布式思想很值得借鉴!这几天闲来无事对Gateway-worker 来学习了Swoole,受益颇多啊

  • 13147010548

    @xys 每个Worker进程和Matser进程间Unix Socket通信,Worker接收到reacort投递的任务,没有任务队列的话就一个个处理吧,这一层没有事件循环啥的

  • 13147010548

    大家觉得我说的不对的地方 希望给出建议,相互促进

  • 13147010548

    BASE模式 个人理解:就是每个Worker进程自己Accept,将client_socket直接加入到当前进程全局事件循环中(GlobbalEventLoop)直接回调注册的处理函数