swoole如何處理高同時
①Reactor模型介紹 #)IO複用非同步非阻塞程式使用經典的Reactor模型,Reactor顧名思義就是反應器的意思,它本身不處理任何資料收發。只是可以監視一個socket(也可以是管道、eventfd、訊號)句柄的事件變化。
Reactor只是一個事件產生器,實際對socket句柄的操作,如connect/accept、send/recv、close是在callback中完成的。
②swoole的架構swoole採用多執行緒Reactor 多進程Worker。
當請求到達時,swoole是這樣處理的:
请求到达 Main Reactor
|
|
Main Reactor根据Reactor的情况,将请求注册给对应的Reactor
(每个Reactor都有epoll。用来监听客户端的变化)
|
|
客户端有变化时,交给worker来处理
|
|
worker处理完毕,通过进程间通信(比如管道、共享内存、消息队列)发给对应的reactor。
|
|
reactor将响应结果发给相应的连接
|
|
请求处理完成
以上是Swoole如何處理高並發的詳細內容。更多資訊請關注PHP中文網其他相關文章!