本教程技术重点:你对 swoole 进程 线程 知道 多少 swoole

你对swoole的进程,线程知道多少

作者:神秘网友 发布时间:2020-11-24 16:01:03

你对swoole的进程,线程知道多少

swoole教程栏目介绍swoole的进程,线程。

你对swoole的进程,线程知道多少

推荐(免费):swoole教程
进程

1、进程之间不共享任何状态
2、进程的调度由操作系统完成
3、每个进程都有自己独立的内存空间
4、进程间通讯主要是通过信号传递的方式来实现的,实现方式有多种,信号量、管道、事件等,任何一种方式的通讯效率都需要过内核,导致通讯效率比较低
5、由于是独立的内存空间,上下文切换的时候需要保存先调用栈的信息、cpu各寄存器的信息、虚拟内存、以及打开的相关句柄等信息,所以导致上下文进程间切换开销很大,通讯麻烦。

线程

1、线程之间共享变量,解决了通讯麻烦的问题对于变量的访问需要锁
2、一个进程可以拥有多个线程,但是其中每个线程会共享父进程像操作系统申请资源,这个包括虚拟内存、文件等,由于是共享资源,所以创建线程所需要的系统资源占用比进程小很多,相应的可创建的线程数量也变得相对多很多。
3、另外在调度方面也是由于内存是共享的,所以上下文切换的时候需要保存的东西就像对少一些,这样一来上下文的切换也变得高效。

解释
  • 通过php,运行一个php文件,这个时候就相当于我们创建了一个进程,这个进程会在系统中驻存,申请属于它自己的内存空间系统资源并且运行相应的程序。
    你对swoole的进程,线程知道多少
    1、Master进程:主进程
    2、Manger进程:管理进程
    3、Worker进程:工作进程
    4、Task进程:异步任务工作进程

    • 第一层,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数据包

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

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

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

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

    client跟server的交互:

    1、client请求到达 Main Reactor,Client实际上是与Master进程中的某个Reactor线程发生了连接。

    2、Main Reactor根据Reactor的情况,将请求注册给对应的Reactor (每个Reactor都有epoll。用来监听客户端的变化)

    3、客户端有变化时Reactor将数据交给worker来处理

    4、worker处理完毕,通过进程间通信(比如管道、共享内存、消息队列)发给对应的reactor。

    5、reactor将响应结果发给相应的连接请求处理完成

    Master进程内的回调函数
    • onStart Server启动在主进程的主线程回调此函数
    • onShutdown 此事件在Server正常结束时发生
    Manager进程内的回调函数
    • onManagerStart 当管理进程启动时调用它
    • onManagerStop 当管理进程结束时调用它
    • onWorkerError 当worker/task_worker进程发生异常后会在Manager进程内回调此函数
    Worker进程内的回调函数
    • onWorkerStart 此事件在Worker进程/Task进程启动时发生
    • onWorkerStop 此事件在worker进程终止时发生。
    • onConnect 有新的连接进入时,在worker进程中回调
    • onClose TCP客户端连接关闭后,在worker进程中回调此函数
    • onReceive 接收到数据时回调此函数,发生在worker进程中
    • onPacket 接收到UDP数据包时回调此函数,发生在worker进程中
    • onFinish 当worker进程投递的任务在task_worker中完成时,task进程会通过finish()方法将任务处理的结果发送给worker进程。
    • onWorkerExit 仅在开启reload_async特性后有效。异步重启特性
    • onPipeMessage 当工作进程收到由 sendMessage 发送的管道消息时会触发事件
    Task进程内的回调函数
    • onTask 在task_worker进程内被调用。worker进程可以使用swoole_server_task函数向task_worker进程投递新的任务
    • onWorkerStart 此事件在Worker进程/Task进程启动时发生
    • onPipeMessage 当工作进程收到由 sendMessage 发送的管道消息时会触发事件
    简单说明:
    • 1、服务器关闭程序终止时最后一次事件是onShutdown。
    • 2、服务器启动成功后,onStart/onManagerStart/onWorkerStart会在不同的进程内并发执行,并不是顺序的。
    • 3、所有事件回调均在$server->start后发生,start之后写的代码是无效代码。
    • 4、onStart/onManagerStart/onWorkerStart 3个事件的执行顺序是不确定的
    swoole运行流程图

    你对swoole的进程,线程知道多少

    进程

    1、进程之间不共享任何状态
    2、进程的调度由操作系统完成
    3、每个进程都有自己独立的内存空间
    4、进程间通讯主要是通过信号传递的方式来实现的,实现方式有多种,信号量、管道、事件等,任何一种方式的通讯效率都需要过内核,导致通讯效率比较低
    5、由于是独立的内存空间,上下文切换的时候需要保存先调用栈的信息、cpu各寄存器的信息、虚拟内存、以及打开的相关句柄等信息,所以导致上下文进程间切换开销很大,通讯麻烦。

    线程

    1、线程之间共享变量,解决了通讯麻烦的问题对于变量的访问需要锁
    2、一个进程可以拥有多个线程,但是其中每个线程会共享父进程像操作系统申请资源,这个包括虚拟内存、文件等,由于是共享资源,所以创建线程所需要的系统资源占用比进程小很多,相应的可创建的线程数量也变得相对多很多。
    3、另外在调度方面也是由于内存是共享的,所以上下文切换的时候需要保存的东西就像对少一些,这样一来上下文的切换也变得高效。

    解释
    • 通过php,运行一个php文件,这个时候就相当于我们创建了一个进程,这个进程会在系统中驻存,申请属于它自己的内存空间系统资源并且运行相应的程序。
      你对swoole的进程,线程知道多少
      1、Master进程:主进程
      2、Manger进程:管理进程
      3、Worker进程:工作进程
      4、Task进程:异步任务工作进程

      • 第一层,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数据包

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

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

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

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

      client跟server的交互:

      1、client请求到达 Main Reactor,Client实际上是与Master进程中的某个Reactor线程发生了连接。

      2、Main Reactor根据Reactor的情况,将请求注册给对应的Reactor (每个Reactor都有epoll。用来监听客户端的变化)

      3、客户端有变化时Reactor将数据交给worker来处理

      4、worker处理完毕,通过进程间通信(比如管道、共享内存、消息队列)发给对应的reactor。

      5、reactor将响应结果发给相应的连接请求处理完成

      Master进程内的回调函数
      • onStart Server启动在主进程的主线程回调此函数
      • onShutdown 此事件在Server正常结束时发生
      Manager进程内的回调函数
      • onManagerStart 当管理进程启动时调用它
      • onManagerStop 当管理进程结束时调用它
      • onWorkerError 当worker/task_worker进程发生异常后会在Manager进程内回调此函数
      Worker进程内的回调函数
      • onWorkerStart 此事件在Worker进程/Task进程启动时发生
      • onWorkerStop 此事件在worker进程终止时发生。
      • onConnect 有新的连接进入时,在worker进程中回调
      • onClose TCP客户端连接关闭后,在worker进程中回调此函数
      • onReceive 接收到数据时回调此函数,发生在worker进程中
      • onPacket 接收到UDP数据包时回调此函数,发生在worker进程中
      • onFinish 当worker进程投递的任务在task_worker中完成时,task进程会通过finish()方法将任务处理的结果发送给worker进程。
      • onWorkerExit 仅在开启reload_async特性后有效。异步重启特性
      • onPipeMessage 当工作进程收到由 sendMessage 发送的管道消息时会触发事件
      Task进程内的回调函数
      • onTask 在task_worker进程内被调用。worker进程可以使用swoole_server_task函数向task_worker进程投递新的任务
      • onWorkerStart 此事件在Worker进程/Task进程启动时发生
      • onPipeMessage 当工作进程收到由 sendMessage 发送的管道消息时会触发事件
      简单说明:
      • 1、服务器关闭程序终止时最后一次事件是onShutdown。
      • 2、服务器启动成功后,onStart/onManagerStart/onWorkerStart会在不同的进程内并发执行,并不是顺序的。
      • 3、所有事件回调均在$server->start后发生,start之后写的代码是无效代码。
      • 4、onStart/onManagerStart/onWorkerStart 3个事件的执行顺序是不确定的
      swoole运行流程图

      你对swoole的进程,线程知道多少

      你对swoole的进程,线程知道多少的教程已介绍完毕,更多请关注跳墙网其他文章教程!

      你对swoole的进程,线程知道多少相关教程

      1. 浅析浏览器是如何调度进程和线程的

        一、线程和进程 首先我们来回顾下线程和进程的概念: 进程: CPU 进行资源分配的基本单位 线程: CPU 调度的最小单位 这是进程和线程最官方也是最常见的两个定义,但是这两个概念太抽象了,很难以理解。 通俗一点讲: 进程可以描述为一个应用程序的执行程序

      2. linux查看进程命令是什么

        linux查看进程的命令有:1、PS命令,该命令可以查看哪些进程正在运行及其运行状态;2、Top命令,该命令可以实时显示各个线程情况;3、Pstree命令,该命令以树状图的方式展现进程之间的派生关系;4、Pgrep命令等等。 推荐:《linux教程》 Linux查看进程命令

      3. 进程资源图的识读、判断节点是否阻塞、化简

        进程资源图的识读、判断节点是否阻塞、化简 让我们来看一下这道13年上半年的软设选择题: 先po答案:空1填B、空2填C ======================================= 如何看进程资源图呢? (1) P:进程 R:一类资源 R中的圆圈数:该类资源有几个 (2) R→P(R指

      4. 操作系统(二)进程的描述与控制

        操作系统(二)进程的描述与控制 进程的描述与控制 前趋图 为了更好的描述程序的顺序和并发执行情况,引入了前趋图,前趋图是一个有向无环图(DAG),它用于描述进程之间执行的先后顺序,图中的每个节点可用来表示一个进程或程序段,乃至一条语句,节点间的有

      5. Linux进程编程记录

        Linux进程编程记录 一、进程相关概念 1.什么是程序,什么是进程,有什么区别 程序是静态的概念,gcc xxx.c -o pro,磁盘中生成的pro文件叫程序 进程是程序的一次的活动,只要程序跑,系统中就多了一个进程 2.如何查看进程 ps 或ps -aux|grep 要查找的进程 3.什

      6. Linux进程间通信方式

        Linux进程间通信方式 管道简介 管道包括三种: - 普通管道pipe: 通常有两种限制,一是单工,只能单向传输;二是只能在父子或者兄弟进程间使用. - 流管道s_pipe: 去除了第一种限制,为半双工,只能在父子或兄弟进程间使用,可以双向传输. - 命名管道:name_pipe:去

      7. 【操作系统】多线程编程

        【操作系统】多线程编程 多线程编程 1.线程是什么 2.进程和线程的区别 3.多线程编程的实现方式 3.1 实例化对象 3.1.1 基于多线程的IP归属地查询 3.2 创建子类 3.2.1 基于多线程的批量主机存活探测 4.共享全局变量 4.1 GIL是什么 4.2 线程同步 4.3 如何实现线

      8. 【操作系统】多进程编程

        【操作系统】多进程编程 进程的五状态图: created:进程已经创建,但未被OS接纳为可执行进程。(还没有申请到相应的资源)。 ready:进程做好了准备,准备执行(只等待处理机)。 running:该进程正在执行(单处理机,某一时刻仅一个进程占用处理机)。 wait

每天更新java,php,javaScript,go,python,nodejs,vue,android,mysql等相关技术教程,教程由网友分享而来,欢迎大家分享IT技术教程到本站,帮助自己同时也帮助他人!

Copyright 2020, All Rights Reserved. Powered by 跳墙网(www.tqwba.com)|网站地图|关键词