getwayworker timer_workerman定时器使用

本文介绍了getwayworker中的timer_workerman定时器的使用方法,包括如何添加定时任务,参数解释,以及不同类型的定时任务示例,如匿名函数、普通函数、类方法、静态方法等,并展示了如何在定时器中销毁当前定时器。
摘要由CSDN通过智能技术生成

From: http://doc3.workerman.net/worker-development/add.html

add

int \Workerman\Lib\Timer::add(float $time_interval, callable $callback [,$args = array(), bool $persistent = true])

定时执行某个函数或者类方法

参数

time_interval

多长时间执行一次,单位秒,支持小数,可以精确到0.001,即精确到毫秒级别。

callback

回调函数注意:如果回调函数是类的方法,则方法必须是public属性

args

回调函数的参数,必须为数组,数组元素为参数值

persistent

是否是持久的,如果只想定时执行一次,则传递false(只执行一次的任务在执行完毕后会自动销毁,不必调用Timer::del())。默认是true,即一直定时执行。

返回值

返回一个整数,代表计时器的timerid,可以通过调用Timer::del($timerid)销毁这个计时器。

示例

1、定时函数为匿名函数(闭包)

use \Workerman\Worker;

use \Workerman\Lib\Timer;

require_once './Workerman/Autoloader.php';

$task = new Worker();

// 开启多少个进程运行定时任务,注意多进程并发问题

$task->count = 1;

$task->onWorkerStart = function($task)

{

// 每2.5秒执行一次

$time_interval = 2.5;

Timer::add($time_interval, function()

{

echo "task run\n";

});

};

// 运行worker

Worker::runAll();

2、定时函数为普通函数

require_once './Workerman/Autoloader.php';

use \Workerman\Worker;

use \Workerman\Lib\Timer;

// 普通的函数

function send_mail($to, $content)

{

echo "send mail ...\n";

}

$task = new Worker();

$task->onWorkerStart = function($task)

{

$to = 'workerman@workerman.net';

$content = 'hello workerman';

// 10秒后执行发送邮件任务,最后一个参数传递false,表示只运行一次

Timer::add(10, 'send_mail', array($to, $content), false);

};

// 运行worker

Worker::runAll();

3、定时函数为类的方法

require_once './Workerman/Autoloader.php';

use \Workerman\Worker;

use \Workerman\Lib\Timer;

class Mail

{

// 注意,回调函数属性必须是public

public function send($to, $content)

{

echo "send mail ...\n";

}

}

$task = new Worker();

$task->onWorkerStart = function($task)

{

// 10秒后发送一次邮件

$mail = new Mail();

$to = 'workerman@workerman.net';

$content = 'hello workerman';

Timer::add(10, array($mail, 'send'), array($to, $content), false);

};

// 运行worker

Worker::runAll();

4、定时函数为类方法(类内部使用定时器)

require_once './Workerman/Autoloader.php';

use \Workerman\Worker;

use \Workerman\Lib\Timer;

class Mail

{

// 注意,回调函数属性必须是public

public function send($to, $content)

{

echo "send mail ...\n";

}

public function sendLater($to, $content)

{

// 回调的方法属于当前的类,则回调数组第一个元素为$this

Timer::add(10, array($this, 'send'), array($to, $content), false);

}

}

$task = new Worker();

$task->onWorkerStart = function($task)

{

// 10秒后发送一次邮件

$mail = new Mail();

$to = 'workerman@workerman.net';

$content = 'hello workerman';

$mail->sendLater($to, $content);

};

// 运行worker

Worker::runAll();

5、定时函数为类的静态方法

require_once './Workerman/Autoloader.php';

use \Workerman\Worker;

use \Workerman\Lib\Timer;

class Mail

{

// 注意这个是静态方法,回调函数属性也必须是public

public static function send($to, $content)

{

echo "send mail ...\n";

}

}

$task = new Worker();

$task->onWorkerStart = function($task)

{

// 10秒后发送一次邮件

$to = 'workerman@workerman.net';

$content = 'hello workerman';

// 定时调用类的静态方法

Timer::add(10, array('Mail', 'send'), array($to, $content), false);

};

// 运行worker

Worker::runAll();

6、定时函数为类的静态方法(带命名空间)

namespace Task;

require_once './Workerman/Autoloader.php';

use \Workerman\Worker;

use \Workerman\Lib\Timer;

class Mail

{

// 注意这个是静态方法,回调函数属性也必须是public

public static function send($to, $content)

{

echo "send mail ...\n";

}

}

$task = new Worker();

$task->onWorkerStart = function($task)

{

// 10秒后发送一次邮件

$to = 'workerman@workerman.net';

$content = 'hello workerman';

// 定时调用带命名空间的类的静态方法

Timer::add(10, array('\Task\Mail', 'send'), array($to, $content), false);

};

// 运行worker

Worker::runAll();

7、定时器中销毁当前定时器(use闭包方式传递$timer_id)

use \Workerman\Worker;

use \Workerman\Lib\Timer;

require_once './Workerman/Autoloader.php';

$task = new Worker();

$task->onWorkerStart = function($task)

{

// 计数

$count = 1;

// 要想$timer_id能正确传递到回调函数内部,$timer_id前面必须加地址符 &

$timer_id = Timer::add(1, function()use(&$timer_id, &$count)

{

echo "Timer run $count\n";

// 运行10次后销毁当前定时器

if($count++ >= 10)

{

echo "Timer::del($timer_id)\n";

Timer::del($timer_id);

}

});

};

// 运行worker

Worker::runAll();

8、定时器中销毁当前定时器(参数方式传递$timer_id)

require_once './Workerman/Autoloader.php';

use \Workerman\Worker;

use \Workerman\Lib\Timer;

class Mail

{

public function send($to, $content, $timer_id)

{

// 临时给当前对象添加一个count属性,记录定时器运行次数

$this->count = empty($this->count) ? 1 : $this->count;

// 运行10次后销毁当前定时器

echo "send mail {$this->count}...\n";

if($this->count++ >= 10)

{

echo "Timer::del($timer_id)\n";

Timer::del($timer_id);

}

}

}

$task = new Worker();

$task->onWorkerStart = function($task)

{

$mail = new Mail();

// 要想$timer_id能正确传递到回调函数内部,$timer_id前面必须加地址符 &

$timer_id = Timer::add(1, array($mail, 'send'), array('to', 'content', &$timer_id));

};

// 运行worker

Worker::runAll();

9、只在指定进程中设置定时器

一个worker实例有4个进程,只在id编号为0的进程上设置定时器。

use Workerman\Worker;

use Workerman\Lib\Timer;

require_once './Workerman/Autoloader.php';

$worker = new Worker();

$worker->count = 4;

$worker->onWorkerStart = function($worker)

{

// 只在id编号为0的进程上设置定时器,其它1、2、3号进程不设置定时器

if($worker->id === 0)

{

Timer::add(1, function(){

echo "4个worker进程,只在0号进程设置定时器\n";

});

}

};

// 运行worker

Worker::runAll();

Linux中的TIMER_REAL定时器是一种基于实时时钟的定时器。它使用了系统的真实时间来进行定时操作。当定时器到期时,会生成一个SIGALRM信号,可以用来触发特定的操作或处理程序。 你可以使用timer_create()函数来创建一个TIMER_REAL定时器。例如: ```c #include <stdio.h> #include <signal.h> #include <unistd.h> #include <time.h> timer_t timerid; void timer_handler(int sig) { printf("Timer expired!\n"); } int main() { struct sigevent sevp; struct itimerspec its; // 设置定时器处理程序 signal(SIGALRM, timer_handler); // 创建定时器 sevp.sigev_notify = SIGEV_SIGNAL; sevp.sigev_signo = SIGALRM; timer_create(CLOCK_REALTIME, &sevp, &timerid); // 设置定时器参数 its.it_value.tv_sec = 5; // 第一次触发的时间(秒) its.it_value.tv_nsec = 0; // 第一次触发的时间(纳秒) its.it_interval.tv_sec = 1; // 重复触发的时间间隔(秒) its.it_interval.tv_nsec = 0; // 重复触发的时间间隔(纳秒) // 启动定时器 timer_settime(timerid, 0, &its, NULL); //等待定时器触发 sleep(10); // 删除定时器 timer_delete(timerid); return 0; } ``` 以上的代码演示了创建一个TIMER_REAL定时器并设置参数,然后等待定时器到期。当定时器到期时,会调用timer_handler函数打印一条信息。这个例子中,定时器将在5秒后第一次触发,然后每1秒重复触发一次。 希望能对你有所帮助!如果你有更多问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值