最新公告
  • 欢迎您光临码农资源网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!加入我们
  • 了解swoole核心进程结构

    Swoole的高效不仅仅于底层使用c编写,他的进程结构模型也使其可以高效的处理业务,我们想要深入学习,并且在实际的场景当中使用必须了解,下面我们先看一下结构图

    swoole进程结构

    首先先介绍下swoole的这几种进程分别是干什么的

    从这些层级的名字,我们先大概说一下,下面这些层级分别是干什么的,做一个详细的说明。

    1、Master进程:主进程

    2、Manger进程:管理进程

    3、Worker进程:工作进程

    4、Task进程:异步任务工作进程

    1、Master进程

    第一层,Master进程,这个是swoole的主进程,这个进程是用于处理swoole的核心事件驱动的,那么在这个进程当中可以看到它拥有一个MainReactor[线程]以及若干个Reactor[线程],swoole所有对于事件的监听都会在这些线程中实现,比如来自客户端的连接,信号处理等。 

    每一个线程都有自己的用途,下面多每个线程有一个了解

    1.1、MainReactor(主线程)

    主线程会负责监听server socket,如果有新的连接accept,主线程会评估每个Reactor线程的连接数量。将此连接分配给连接数最少的reactor线程,做一个负载均衡。

    1.2 、Reactor线程组

    Reactor线程负责维护客户端机器的TCP连接、处理网络IO、收发数据完全是异步非阻塞的模式

    swoole的主线程在Accept新的连接后,会将这个连接分配给一个固定的Reactor线程socket可读时读取数据,并进行协议解析,将请求投递到Worker进程。在socket可写时将数据发送给TCP客户端。

    1.3、心跳包检测线程(HeartbeatCheck)

    Swoole配置了心跳检测之后,心跳包线程会在固定时间内对所有之前在线的连接

    发送检测数据包

    1.4、UDP收包线程UdpRecv)

    接收并且处理客户端udp数据包

    2、管理进程Manager

    Swoole想要实现最好的性能必须创建出多个工作进程帮助处理任务,但Worker进程就必须fork操作,但是fork操作是不安全的,如果没有管理会出现很多的僵尸进程,进而影响服务器性能,同时worker进程被误杀或者由于程序的原因会异常退出,为了保证服务的稳定性,需要重新创建worker进程。

    Swoole在运行中会创建一个单独的管理进程,所有的worker进程和task进程都是从管理进程Fork出来的。管理进程会监视所有子进程的退出事件,当worker进程发生致命错误或者运行生命周期结束时,管理进程会回收此进程,并创建新的进程。换句话也就是说,对于workertask进程的创建、回收等操作全权有“保姆”Manager进程进行管理。

    再来一张图梳理下Manager进程和Worker/Task进程的关系。

    3、Worker进程

    worker 进程属于swoole的主逻辑进程,用户处理客户端的一系列请求,接受由Reactor线程投递的请求数据包,并执行PHP回调函数处理数据生成响应数据并发给Reactor线程,由Reactor线程发送给TCP客户端可以是异步非阻塞模式,也可以是同步阻塞模式

    4、Task进程

    taskWorker进程这一进城是swoole提供的异步工作进程,这些进程主要用于处理一些耗时较长的同步任务,在worker进程当中投递过来。

    想要了解更多内容,请持续关注码农资源网,一起探索发现编程世界的无限可能!
    本站部分资源来源于网络,仅限用于学习和研究目的,请勿用于其他用途。
    如有侵权请发送邮件至1943759704@qq.com删除

    码农资源网 » 了解swoole核心进程结构
    • 7会员总数(位)
    • 25846资源总数(个)
    • 0本周发布(个)
    • 0 今日发布(个)
    • 293稳定运行(天)

    提供最优质的资源集合

    立即查看 了解详情