# swoole回调函数
[TOC=2,3]
在swoole中,一个swoole_server的拥有若干回调函数,这些回调函数决定了swoole_server的相关功能。可以通过
```php
$serv->on( string $event, mixed $callback );
```
函数来配置.
示例:
```php
class Server
{
private $serv;
public function __construct() {
$this->serv = new swoole_server("0.0.0.0", 9501);
$this->serv->set(array(
'worker_num' => 8,
'daemonize' => false,
'max_request' => 10000,
'dispatch_mode' => 2,
'debug_mode'=> 1
));
$this->serv->on('Start', array($this, 'onStart'));
$this->serv->on('Connect', array($this, 'onConnect'));
$this->serv->on('Receive', array($this, 'onReceive'));
$this->serv->on('Close', array($this, 'onClose'));
$this->serv->start();
}
}
```
全部回调函数以及相关介绍如下:
#### **1.onReceive**
描述:接收数据的回调<br>
函数原型:<br>
```php
function onReceive( swoole_server $serv, $fd, $from_id, $data );
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$fd | 连接的描述符
$from_id | reactor的id,无用
$data | 接收到的数据
说明:每当server接收到客户端发来的数据后,就会通过onReceive回调将数据投递给Worker。如果开启了协议检测,则会在收到完整数据包之后才会响应回调。注意,必须设置该回调函数,否则无法启动服务器。
#### **2.onStart**
描述:服务器启动的回调<br>
函数原型:<br>
```php
function onStart( swoole_server $serv);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
说明:<br>
onStart事件在Master进程的主线程中被调用。在此回调响应之前Swoole Server已进行了如下操作<br>
- 已创建了manager进程
- 已创建了worker子进程
- 已监听所有TCP/UDP端口
- 已监听了定时器
接下来要执行<br>
- 主Reactor开始接收事件,客户端可以connect到Server
onStart回调中,仅允许echo、打印Log、修改进程名称。不得执行其他操作。onWorkerStart和onStart回调是在不同进程中并行执行的,不存在先后顺序。
可以在onStart回调中,将**$serv->master_pid**和**$serv->manager_pid**的值保存到一个文件中。这样可以编写脚本,向这两个PID发送信号来实现关闭和重启的操作。<br>
从1.7.5+ Master进程内不再支持定时器,onMasterConnect/onMasterClose2个事件回调也彻底移除。Master进程内不再保留任何PHP的接口。<br>
在onStart中创建的全局资源对象不能在worker进程中被使用,因为发生onStart调用时,worker进程已经创建好了。新创建的对象在主进程内,worker进程无法访问到此内存区域,因此全局对象创建的代码需要放置在swoole_server_start之前。<br>
#### **3.onWorkerStart**
描述:Worker进程启动的回调<br>
函数原型:<br>
```php
function onWorkerStart( swoole_server $serv,int $worker_id);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$worker_id| Worker进程的id
说明:此事件在worker进程/task_worker启动时发生。
> 发生PHP致命错误或者代码中主动调用exit时,Worker/Task进程会退出,管理进程会重新创建新的进程
onWorkerStart/onStart是并发执行的,没有先后顺序
通过$worker_id参数的值来,判断worker是普通worker还是task_worker。$worker_id>= $serv->setting['worker_num'] 时表示这个进程是task_worker。<br>
如果想使用swoole_server_reload实现代码重载入,必须在workerStart中require你的业务文件,而不是在文件头部。在onWorkerStart调用之前已包含的文件,不会重新载入代码。<br>
可以将公用的,不易变的php文件放置到onWorkerStart之前。这样虽然不能重载入代码,但所有worker是共享的,不需要额外的内存来保存这些数据。<br>
onWorkerStart之后的代码每个worker都需要在内存中保存一份
$worker_id是一个从0-$worker_num之间的数字,表示这个worker进程的ID
$worker_id和进程PID没有任何关系<br>
#### **4.onConnect**
描述:新连接接入时的回调<br>
函数原型:<br>
```php
function onConnect( swoole_server $serv,int $fd, int $from_id);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$fd | 连接的描述符
$from_id | reactor的id,无用
说明:有新的连接进入时,在worker进程中回调。onConnect/onClose这2个回调发生在worker进程内,而不是主进程。如果需要在主进程处理连接/关闭事件,请注册onMasterConnect/onMasterClose回调。onMasterConnect/onMasterClose回调总是先于onConnect/onClose被执行
#### **5.onClose**
描述:连接关闭时的回调<br>
函数原型:<br>
```php
function onClose( swoole_server $serv,int $fd, int $from_id);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$fd | 连接的描述符
$from_id | reactor的id,无用
说明:TCP客户端连接关闭后,在worker进程中回调此函数。无论close由客户端发起还是服务器端主动调用**swoole_server_close**关闭连接,都会触发此事件。
因此只要连接关闭,就一定会回调此函数。
#### **6.onTask**
描述:task_worker进程处理任务的回调<br>
函数原型:<br>
```php
function onTask(swoole_server $serv, int $task_id, int $from_id, string $data);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$task_id | 任务ID
$from_id | 来自于哪个worker进程
$data | 任务内容
说明:在task_worker进程内被调用。worker进程可以使用swoole_server_task函数向task_worker进程投递新的任务。可以直接将任务结果字符串通过return方式返回给worker进程。worker进程将在[onFinish](#7onfinish)回调中收到结果。注:如果serv->set(array('task_worker_num' => 8)) task_id 并不是从1-8 而是递增的。
#### **7.onFinish**
描述:task_worker进程处理任务结束的回调<br>
函数原型:<br>
```php
function onFinish(swoole_server $serv, int $task_id, string $data);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$task_id | 任务ID
$data | 任务结果
说明:在此函数中会收到任务处理的结果,通过task_id和worker_id来区分不同的任务。
#### **8.onTimer**
描述:定时器触发的回调<br>
函数原型:<br>
```php
function onTimer(swoole_server $serv, int $interval);
```
参数 | 描述
-------- | ---------
$serv | swoole_server对象
$interval | 定时的间隔
说明:定时器被触发时,该函数被调用。通过interval来区分不同时间间隔的定时器。
其余回调函数请参看[swoole wiki](http://wiki.swoole.com/wiki/page/41.html)
- swoole简介
- swoole功能概述
- 序章
- 开发必读
- 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支持
- 2.9 热重启
- 2.10 http_server
- 附录*server配置
- 附录*server函数
- 附录*server属性
- 附录*server回调函数
- 附录*server高级特性
- 心跳检测
- 3 Swoole协议
- 3.1 EOF协议
- 3.2 固定包头协议
- 3.3 Http协议
- 3.4 WebSocket协议
- 3.5 MTQQ协议
- 内置http_server
- 内置websocket_server
- Swoole\Redis\Server
- 4 Swoole异步IO
- 4.1 AsyncIO
- 异步文件系统IO
- swoole_async_readfile
- swoole_async_writefile
- swoole_async_read
- swoole_async_write
- 5 swoole异步客户端
- ws_client
- http_client
- mysql_client
- redis_client
- tcp_client
- http2_client
- 6 swoole协程
- Swoole\Coroutine\Http\Client
- Swoole\Coroutine\MySQL
- Swoole\Coroutine\Redis
- Coroutine\PostgreSQL
- Swoole\Coroutine\Client
- Swoole\Coroutine\Socket
- Swoole\Coroutine\Channel
- Coroutine
- Swoole\Coroutine::create
- Swoole\Coroutine::resume
- Swoole\Coroutine::suspend
- Swoole\Coroutine::sleep
- Coroutine::getaddrinfo
- Coroutine::gethostbyname
- swoole_async_dns_lookup_coro
- Swoole\Coroutine::getuid
- getDefer
- setDefer
- recv
- Coroutine::stats
- Coroutine::fread
- Coroutine::fget
- Coroutine::fwrite
- Coroutine::readFIle
- Coroutine::writeFIle
- Coroutine::exec
- 7 swoole_process
- process::construct
- process::start
- process::name
- process::signal
- process::setaffinity
- process::exit
- process::kill
- process::daemon
- process->exec
- process::wait
- process::alarm
- 8 swoole定时器
- swoole_timer_tick
- swoole_timer_after
- swoole_timer_clear
- 9 swoole_event
- swoole_event_add
- swoole_event_set
- swoole_event_del
- swoole_event_wait
- swoole_event_defer
- swoole_event_write
- swoole_event_exit
- swoole提供的function
- 常见问题
- 客户端链接失败原因
- 如何设置进程数
- 如何实现异步任务
- 如何选择swoole三种模式
- php中哪些函数是阻塞的
- 是否可以共用1个redis或mysql连接
- 如何在回调函数中访问外部的变量
- 为什么不要send完后立即close
- 不同的Server程序实例间如何通信
- MySQL的连接池、异步、断线重连
- 在php-fpm或apache中使用swoole
- 学习Swoole需要掌握哪些基础知识
- 在phpinfo中有在php-m中没有
- 同步阻塞与异步非阻塞选择
- CURL发送POST请求服务器端超时
- 附录
- 预定义常量
- 内核参数调优
- php四种回调写法
- 守护进程程序常用数据结构
- swoole生命周期
- swoole_server中内存管理机制
- 使用jemalloc优化swoole内存分配性能
- Reactor、Worker、Task的关系
- Manager进程
- Swoole的实现
- Reactor线程
- 安装扩展
- swoole-worker手册
- swoole相关开源项目
- 写在后面的话
- 版本更新记录
- 4.0