• swoole详解


    1、swoole结构图

    2、swoole流程图

    3、详细流程图

    3.1、Master:处理核心事件驱动(主进程)
    3.2、Reactor:
      处理TCP连接,收发数据的线程。Swoole的主线程在Accept新的连接后,会将这个连接分配给一个固定的Reactor线程,并由这个线程负责监听此socket。在socket可读时读取数据,并进行协议解析,将请求投递到Worker进程。在socket可写时将数据发送给TCP客户端。,

      3.2.1、负责维护客户端TCP连接、处理网络IO、处理协议、收发数据
      3.2.2完全是异步非阻塞的模式
      3.2.3、全部为C代码,除Start/Shudown事件回调外,不执行任何PHP代码
      3.2.4、将TCP客户端发来的数据缓冲、拼接、拆分成完整的一个请求数据包
      3.2.5、Reactor以多线程的方式运行
    3.3、Manager进程:

      3.3.1、swoole中worker/task进程都是由Manager进程Fork并管理的。
      3.3.2、子进程结束运行时,manager进程负责回收此子进程,避免成为僵尸进程。并创建新的子进程
      3.3.3、服务器关闭时,manager进程将发送信号给所有子进程,通知子进程关闭服务
      3.3.4、服务器reload时,manager进程会逐个关闭/重启子进程
    3.4、Worker进程:处理客户端请求

      3.4.1、接受由Reactor线程投递的请求数据包,并执行PHP回调函数处理数据
      3.4.2、生成响应数据并发给Reactor线程,由Reactor线程发送给TCP客户端
      3.4.3、可以是异步非阻塞模式,也可以是同步阻塞模式
      3.4.4、Worker以多进程的方式运行
    3.5、Task进程:异步工作进程

      3.5.1、接受由Worker进程通过swoole_server->task/taskwait方法投递的任务
      3.5.2、处理任务,并将结果数据返回(swoole_server->finish)给Worker进程
      3.5.3、完全是同步阻塞模式
      3.5.4、TaskWorker以多进程的方式运行
    3.6、Reactor、Worker、TaskWorker的关系:

      3.6.1、可以理解为Reactor就是nginx,Worker就是php-fpm。Reactor线程异步并行地处理网络请求,然后再转发给Worker进程中去处理。Reactor和Worker间通过UnixSocket进行通信。

      3.6.2、在php-fpm的应用中,经常会将一个任务异步投递到Redis等队列中,并在后台启动一些php进程异步地处理这些任务。Swoole提供的Worker是一套更完整的方案,将任务的投递、队列、php任务处理进程管理合为一体。通过底层提供的API可以非常简单地实现异步任务的处理。另外TaskWorker还可以在任务执行完成后,再返回一个结果反馈到Worker。

      3.6.3、Swoole的Reactor、Worker、TaskWorker之间可以紧密的结合起来,提供更高级的使用方式。

      3.6.4、一个更通俗的比喻,假设Server就是一个工厂,那Reactor就是销售,接受客户订单。而Worker就是工人,当销售接到订单后,Worker去工作生产出客户要的东西。而TaskWorker可以理解为行政人员,可以帮助Worker干些杂事,让Worker专心工作。

      3.6.5、底层会为Worker进程、TaskWorker进程分配一个唯一的ID
      3.6.6、不同的Worker和TaskWorker进程之间可以通过sendMessage接口进行通信

    3.7、 Task进程

      Task流程图 

    • Task和Worker进程的通信通过unix socket进行
    • Task数据传递大小小于8K直接管道传递,大于8K写入临时文件传递
    • Task传递对象 i.可以通过序列化传递一个对象的拷贝(非应用)ii.Task对象的改变不会反应到worker中(连个进程中是独立的)iii.数据库连接,网络连接对象不可传递
    • Task的Onfinish的回调会传递给调用给该task方法的worker进程(原路返回可寻)

    Task 用途: 
    模拟Mysql连接池

    3. 8、Timer定时器

    • Timer基于epoll的timeout机制实现
    • 使用堆存放Timer,提高检索效率
  • 相关阅读:
    通过ssh反向代理相对安全的使用docker2375端口
    Django在现有数据库表中新增/修改字段
    python 判断多边形顺逆时针
    .stl 转ply
    python 求直线延长线和矩形的交点
    python Pillow画图总结
    djangoapscheduler插件来实现Django中的定时任务
    cxf 线程安全
    MySQL的全文搜索索引
    [Conda] Conda/Miniconda简单配置与使用
  • 原文地址:https://www.cnblogs.com/liugp/p/11306442.html
Copyright © 2020-2023  润新知