php swoole理解,php swoole 工作流程

e130ecd4af30876154b359693fbaa474.png

1.Master进程

master进程为主进程,该进程会创建Manager进程和Reactor线程等工作进/线程

swoole的主进程,是个多线程的程序.

主进程内的回调函数:

onStart

onShutdown

onMasterConnect

onMasterClose

onTimer

2.Reactor线程

Reactor线程是真正处理TCP连接,收发数据的线程。

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

3.Manager进程

Manager进程是管理进程,该进程是为了创建管理所有的woker进程和TaskWorker进程,swoole中worker/task进程都是由Manager进程Fork并管理的。(master主进程为多线程进程,不能安全的执行fork操作)

子进程结束运行时,manager进程负责回收此子进程,避免成为僵尸进程。并创建新的子进程

服务器关闭时,manager进程将发送信号给所有子进程,通知子进程关闭服务

服务器reload时,manager进程会逐个关闭/重启子进程

管理进程内的回调函数

onManagerStart

onManagerStop

4.Worker进程

worker进程是工作进程,所有的业务逻辑都在该进程中进行,当Reactor线程接收到来自客户端的数据后,会将数据打包通过管道发送给某个Worker进程.

Swoole提供了完善的进程管理机制,当Worker进程异常退出,如发生PHP的致命错误、被其他程序误杀,或达到max_request次数之后正常退出。主进程会重新拉起新的Worker进程。 Worker进程内可以像普通的apache+php或者php-fpm中写代码。不需要像Node.js那样写异步回调的代码。

Worker进程内的回调函数

onWorkerStart

onWorkerStop

onConnect

onClose

onReceive

onTimer

onFinish

5.TaskWorker进程

Swoole的业务逻辑部分是同步阻塞运行的,如果遇到一些耗时较大的操作,例如访问数据库、广播消息等,就会影响服务器的响应速度。因此Swoole提供了Task功能,将这些耗时操作放到另外的进程去处理,当前进程继续执行后面的逻辑

task进程必须是同步阻塞的,task进程支持定时器

task_worker进程内的回调函数

onTask

onWorkerStart

reactor线程 worker多进程工作流程

Reactor线程

负责维护客户端TCP连接、处理网络IO、处理协议、收发数据

完全是异步非阻塞的模式

全部为C代码,除Start/Shudown事件回调外,不执行任何PHP代码

将TCP客户端发来的数据缓冲、拼接、拆分成完整的一个请求数据包

Reactor以多线程的方式运行

Worker多进程

接受由Reactor线程投递的请求数据包,并执行PHP回调函数处理数据

生成响应数据并发给Reactor线程,由Reactor线程发送给TCP客户端

可以是异步非阻塞模式,也可以是同步阻塞模式

Worker以多进程的方式运行

TaskWorker进程

接受由Worker进程通过swoole_server->task/taskwait方法投递的任务

处理任务,并将结果数据返回(swoole_server->finish)给Worker进程

完全是同步阻塞模式

TaskWorker以多进程的方式运行

关系:

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

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

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

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

底层会为Worker进程、TaskWorker进程分配一个唯一的ID

不同的Worker和TaskWorker进程之间可以通过sendMessage接口进行通信

tsf (Tencent Server Framework) 是腾讯公司推出的 PHP 协程方案,基于 Swoole PHP Generator 实现的 Coroutine。Tencent Server Framework 是快速服务器部署框架,PHP 现在可以像 Golang 一样用协程实现高并发服务器,同时支持同步阻塞,异步非阻塞回调,协程这 3 种 IO 模型。 主要特性: 基于 PHP,相比 C 开发更高效 基于 Swoole 扩展,强大的异步 IO 支持 PHP coroutine 支持服务器监控器和提供接口 要求: php5.5 Swoole1.7.18 linux,OS X 服务器配置: vim server.ini [server] ;server type:tcp,udp,http type = http ; port listen[] = 12312 ; entrance file root = '/data/web_deployment/serv/test/index.php' ;php start path php = '/usr/local/php/bin/php' [setting] ; worker process num worker_num = 16 ; task process num task_worker_num = 0 ; dispatch mode dispatch_mode = 2 ; daemonize daemonize = 1 ; system log log_file = '/data/log/test.log' 启动服务器: cd /root/tsf/bin/ php swoole testHttpServ start 使用 TCP/UDP/HTTP 客户端:   $tcpReturn=(yield $this->tcpTest());   $udpReturn=(yield $this->udpTest());   $httpReturn=(yield $this->httpTest());   public function tcpTest(){     $ip = '127.0.0.1';     $port = '9905';     $data = 'test';     $timeout = 0.5; //second     yield new Swoole\Client\TCP($ip, $port, $data, $timeout);   }   public function udpTest(){     $ip = '127.0.0.1';     $port = '9905';     $data = 'test';     $timeout = 0.5; //second     yield new Swoole\Client\UDP($ip, $port, $data, $timeout);   }   public function httpTest(){     $url='http://www.qq.com';     $httpRequest= new Swoole\Client\HTTP($url);     $data='testdata';     $header = array(       'Content-Length' => 12345,     );     yield $httpRequest->get($url); //yield $httpRequest->post($path, $data, $header);   }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值