onWorkerReload
要求 (workerman >= 3.2.5)
说明:
php
callback Worker::$onWorkerReload
此特性不常用到。
设置 Worker 收到 reload 信号后执行的回调。
可以利用 onWorkerReload 回调做很多事情,例如在不需要重启进程的情况下重新加载业务配置文件。
注意:
子进程收到 reload 信号默认的动作是退出重启,以便新进程重新加载业务代码完成代码更新。所以 reload 后子进程在执行完 onWorkerReload 回调后便立刻退出是正常现象。
如果在收到 reload 信号后只想让子进程执行 onWorkerReload,不想退出,可以在初始化 Worker 实例时设置对应的 Worker 实例的 reloadable 属性为 false。
回调函数的参数
$worker
即 Worker 对象
范例
php
use Workerman\Worker;
require_once __DIR__ . '/vendor/autoload.php';
$worker = new Worker('websocket://0.0.0.0:8484');
// 设置reloadable为false,即子进程收到reload信号不执行重启
$worker->reloadable = false;
// 执行reload后告诉所有客户端服务端执行了reload
$worker->onWorkerReload = function(Worker $worker)
{
foreach($worker->connections as $connection)
{
$connection->send('worker reloading');
}
};
// 运行worker
Worker::runAll();
提示:除了使用匿名函数作为回调,还可以参考这里使用其它回调写法。