onWorkerStart

此事件在worker进程/task进程启动时发生。这里创建的对象可以在进程生命周期内使用。原型:

function onWorkerStart(swoole_server $server, int $worker_id);

swoole1.6.11之后task_worker中也会触发onWorkerStart
发生PHP致命错误或者代码中主动调用exit时,Worker/Task进程会退出,管理进程会重新创建新的进程
onWorkerStart/onStart是并发执行的,没有先后顺序

通过$worker_id参数的值来,判断worker是普通worker还是task_worker。 $worker_id >= $serv->setting['worker_num']时表示这个进程是task_worker.

下面的示例用于为task_worker和worker进程重命名。

$serv->on('WorkerStart', function ($serv, $worker_id){
    global $argv;
    if($worker_id >= $serv->setting['worker_num']) {
        swoole_set_process_name("php {$argv[0]} task worker");
    } else {
        swoole_set_process_name("php {$argv[0]} event worker");
    }
});

如果想使用swoole_server_reload实现代码重载入,必须在workerStart中require你的业务文件,而不是在文件头部。在onWorkerStart调用之前已包含的文件,不会重新载入代码。

可以将公用的,不易变的php文件放置到onWorkerStart之前。这样虽然不能重载入代码,但所有worker是共享的,不需要额外的内存来保存这些数据。
onWorkerStart之后的代码每个worker都需要在内存中保存一份