swoole_server->addtimer
最后更新于:2022-04-02 06:42:31
# swoole\_server->addtimer
~~~
此方法已移除,请勿使用
~~~
设置定时器。1.6.12版本前此函数不能用在消息队列模式下,1.6.12后消息队列IPC模式也可以使用定时器。
~~~
bool swoole_server->addtimer(int $interval);
bool swoole_server_addtimer(swoole_server $serv, int $interval);
~~~
第二个参数是定时器的间隔时间,单位为毫秒。swoole定时器的最小颗粒是1毫秒。支持多个定时器。此函数可以用于worker进程中。
* swoole1.6.5之前支持的单位是秒,所以1.6.5之前传入的参数为1,那在1.6.5后需要传入1000
* swoole1.6.5之后,addtimer必须在onStart/onWorkerStart/onConnect/onReceive/onClose等回调函数中才可以使用,否则会抛出错误。并且定时器无效
* 注意不能存在2个相同间隔时间的定时器
* 即使在代码中多次添加一个定时器,也只会有1个生效
> 1.7.5之后onStart回调中不再支持定时器
> 建议使用tick定时器,addtimer定时器未来或将移除
**增加定时器后需要为Server设置onTimer回调函数,否则Server将无法启动**。多个定时器都会回调此函数。在这个函数内需要自行switch,根据interval的值来判断是来自于哪个定时器。
面向对象风格:
~~~
$serv->addtimer(1000); //1s
$serv->addtimer(20); //20ms
~~~
~~~
$serv->on('Timer', 'my_OnTimer');
function my_OnTimer($serv, $interval)
{
echo "Timer[$interval] is call\n";
}
~~~
';