前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【swoole】如果使用好定时器功能

【swoole】如果使用好定时器功能

作者头像
码缘
发布2019-09-11 19:57:57
4460
发布2019-09-11 19:57:57
举报
文章被收录于专栏:PHP修行之路PHP修行之路

swoole中提供了一个定期器的用法

代码语言:javascript
复制
$server->tick(1000, function() use ($server, $fd) {
        $server->send($fd, "hello world");
    });

开始的时候我是这么用的,看下代码

代码语言:javascript
复制
<?php

$serv = new Swoole\Server("0.0.0.0", 9501);

$serv->set(array(
    'worker_num' => 1,    //worker process num
));

$serv->on('connect', function ($serv, $fd){
    echo "客户端 ".$fd."连接成功 \n";
});
$serv->on('receive', function ($serv, $fd, $reactor_id, $data) {
    echo "客户端 ".$fd."发来消息:".$data."\n";
    $serv->send($fd, 'Swoole已经介绍到您发送的消息: '.$data);
});
$serv->on('close', function ($serv, $fd) {
    echo "客户端 {$fd}关闭连接\n";
});

$serv->on('WorkerStart', function ($serv, $worker_id){
    $serv->tick(2000, function(){
        echo "执行定时器任务 ".time()." \n";
    });
});

$serv->start();

开始使用定时器的时候我放到了 onWorkStart 中执行,这样做的话可以保证在单个worker进程的情况下定时器可以正常运行,但是对于swoole来说让它单进程工作显然辱没了它的 "才华" ,于是我将 work_num 设置为2 然后意外就发生啦,如图

我们可以看到有两个定期器在工作一个任务执行了相同的两次,于是这种方法是不对的,当然我们可以在 onWorkStart 中通过判断 worker_id 来避免这种情况,但是后来我发现其实还有另外一种相对来说好点的方法,就是使用 用户自定义进程来做

代码语言:javascript
复制
bool Server->addProcess(Process $process);

代码如下:

代码语言:javascript
复制
<?php

$serv = new Swoole\Server("0.0.0.0", 9501);

$serv->set(array(
    'worker_num' => 2,    //worker process num
));

//创建自定义进程
$process = new Swoole\Process(function($process) use ($serv) {
    $serv->tick(2000, function(){
        echo "执行定时器任务 ".time()." \n";
    });
});

$serv->addProcess($process);

$serv->on('connect', function ($serv, $fd){
    echo "客户端 ".$fd."连接成功 \n";
});
$serv->on('receive', function ($serv, $fd, $reactor_id, $data) {
    echo "客户端 ".$fd."发来消息:".$data."\n";
    $serv->send($fd, 'Swoole已经介绍到您发送的消息: '.$data);
});
$serv->on('close', function ($serv, $fd) {
    echo "客户端 {$fd}关闭连接\n";
});

$serv->start();

执行效果:

ok!完美执行

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-04-13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档