# Worker進程
---
<!-- toc -->
## Swoole進程模型
首先,我們需要了解一下Swoole的進程模型。Swoole是一個多進程模式的框架(可以類比Nginx的進程模型),當啟動一個Swoole應用時,一共會創建2 + n + m個進程,其中n為Worker進程數,m為TaskWorker進程數,2為一個Master進程和一個Manager進程,它們之間的關系如下圖所示。

其中,Master進程為主進程,該進程會創建Manager進程、Reactor線程等工作進/線程。
* Reactor線程實際運行epoll實例,用于accept客戶端連接以及接收客戶端數據;
* Manager進程為管理進程,該進程的作用是創建、管理所有的Worker進程和TaskWorker進程。
## Worker進程簡介
Worker進程作為Swoole的工作進程,所有的業務邏輯代碼均在此進程上運行。當Reactor線程接收到來自客戶端的數據后,會將數據打包通過管道發送給某個Worker進程(數據分配方法見[dispatch_mode](http://www.baidu.com))。
## Worker進程生命周期
一個Worker進程的生命周期如圖所示:
<!-- {% flowchart %}
st=>start: Create
start=>operation: onWorkerStart
recv=>operation: onReceive/onConnect/onClose
op=>operation: Receive and Handle Data
cond=>condition: Max Request or Error
stop=>operation: onWorkerStop
e=>end: Stop
st->start->recv->op->cond
cond(yes)->stop
cond(no)->recv
stop->e
{% endflowchart %}
-->
當一個Worker進程被成功創建后,會調用`onWorkerStart`回調,隨后進入事件循環等待數據。當通過回調函數接收到數據后,開始處理數據。如果處理數據過程中出現嚴重錯誤導致進程退出,或者Worker進程處理的總請求數達到指定上限,則Worker進程調用`onWorkerStop`回調并結束進程。
- 序章
- 1 環境搭建
- 1.1 環境搭建
- 1.2 搭建Echo服務器
- 2 初識Swoole
- 2.1 Worker進程
- 2.2 TaskWorker進程
- 2.3 Timer定時器
- 2.4 Process進程
- 2.5 Table內存表
- 2.6 多端口監聽
- 2.7 sendfile文件支持
- 2.8 SSL支持
- 3 Swoole協議
- 3.1 EOF協議
- 3.2 固定包頭協議
- 3.3 Http協議
- 3.4 WebSocket協議
- 3.5 MTQQ協議
- 4 Swoole客戶端
- 4.1 Client
- 4.2 異步Http客戶端
- 4.3 異步WebSocket客戶端
- 4.4 異步MySQL客戶端
- 4.5 異步Redis客戶端
- 5 Swoole異步IO
- 5.1 AsyncIO
- 5.2 EventLoop
- 6 Swoole使用
- 7 框架應用
- 7.1 ZPHP
- 7.2 TSF
- 7.3 Hprose
- 7.4 Dora-rpc
- 8 已有框架支持
- 8.1 Yaf
- 8.2 Phalcon
- 8.3 Thinkphp
- 9 項目實戰
- 附錄*配置選項
- 附錄*回調函數
- 附錄*屬性列表
- 附錄*函數列表