![]()
![]()
![]()
(1):Master:处理核心事件驱动(主进程)
(2):Reactor:
处理TCP连接,收发数据的线程,Swoole的主线程在Accept新的连接后,会将这个连接分配给一个固定的Reactor线程,并由这个线程负责监听此socket,在socket可读时读取数据,并进行协议解析,将请求投递到Worker进程,在数据可写时将数据发送给TCP客户端;
a:负责维护客户端TCP连接,处理网络IO,处理协议,收发数据
b:完全是异步非阻塞的模式
c:全部为C代码,除了Start\Shudown事件回调外,不执行任何PHP代码
d:将TCP客户端发来的数据缓存,拼接,拆分成完整的一个请求数据包
e:Reactor以多线程的方式运行
(3):Manager进程:
a:swoole中worker/task进程都是由Manager进程Fork并管理的;
b:子进程结束运行时,manager进程负责回收此子进程,避免成为僵尸进程,并创建新的子进程;
c:服务器关闭时,manager进程将发送信号给所有的子进程,通知子进程关闭服务
d:服务器reload时,manager进程会逐个关闭/重启子进程
(4):Worker进程:处理客户端的请求
a:接收由Reactor线程投递的请求数据包,并执行PHP回调函数处理的数据
b:生成响应数据并发给Reactor线程,由Reactor线程发送给TCP客户端;
c:可以是异步非阻塞模式,也可以是同步阻塞模式
d:Worker以多进程的方式运行;
(5):Task进程:异步工作进程
a:接收由Worker进程通过swoole_server->task/taskwait方法投递的任务;
b:处理任务,并将结果数据返回(swoole_server->finsish)给Worker进程;
c:完全是同步阻塞模式
d:TaskWorker以多进程的方式运行
(6):Reactor,Worker,TaskWorker的关系
a:可以理解为Reactor就是nginx,Worker就是php-fpm,Reactor线程异步并行的处理网络请求,然后再转发给Worker进程中去处理,Reactor和Worker间通过UnixSocket进行通信;
b:在php-fpm的应用中,经常会将一个任务异步投递到Redis等队列中,并在后台启动一些php进程异步的去处理这些任务,Swoole提供的的Worker是一套更完整的方案,将任务的投递,队列,php任务处理进程管理合为一体,通过底层提供的API可以非常简单地实现异步任务的处理,另外
TaskWorker还可以在任务执行完成后,再返回一个结果反馈到Worker.
c:Swoole的Reactor,Worker,TaskWorker之间可以紧密的联系起来,提供更高级的使用方式;
d:一个更通俗的的比喻,假设Server是一个工厂,那Reactor就是销售,接收客户订单,而Worker就是工厂,当销售接到订单后,Worker去工作生产出客户要的东西,而TaskWorker可以理解为行政人员,可以帮助Worker干些杂事,让Worker专心工作;
e:底层会为Worker进程,TaskWorker进程分配一个唯一的ID;
f:不同的Worker和Task进程之间可以通过sendMessage接口进行通信
(7):Task进程
![]()
a:Task和Worker进程的通信通过unix socket进行
b:Task数据传递大小小于8K直接管道传递,大于8K写入临时文件传递
c:Task传递对象
(1):可以通过序列化传递一个对象的拷贝(非应用)
(2):Task对象的改变不会反应到worker中(两个进程中是独立的)
(3):数据库连接,网络连接对象不可传递
d:Task的Onfinish的回调会传递给调用该task方法的worker进程(原路返回可寻)
e:Task用途:模拟Mysql连接池
(8):Timer定时器
![]()
a:Timer基于epoll的超时机制实现
b:使用堆存放Timer,提高检索效率