crontab 定時任務元件
說明
workerman/crontab 類似於 Linux 的 crontab,不同的是 workerman/crontab 支援秒級定時。
時間說明:
0 1 2 3 4 5
| | | | | |
| | | | | +------ day of week (0 - 6) (Sunday=0)
| | | | +------ month (1 - 12)
| | | +-------- day of month (1 - 31)
| | +---------- hour (0 - 23)
| +------------ min (0 - 59)
+-------------- sec (0-59)[可省略,若沒有第 0 位,則最小時間粒度為分鐘]
專案網址
https://github.com/walkor/crontab
安裝
composer require workerman/crontab
使用
步驟一:建立進程檔 app/process/Task.php
<?php
namespace app\process;
use Workerman\Crontab\Crontab;
class Task
{
public function onWorkerStart()
{
// 每秒執行一次
new Crontab('*/1 * * * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
// 每 5 秒執行一次
new Crontab('*/5 * * * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
// 每分鐘執行一次
new Crontab('0 */1 * * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
// 每 5 分鐘執行一次
new Crontab('0 */5 * * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
// 每分鐘的第一秒執行
new Crontab('1 * * * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
// 每天 7 點 50 分執行,此處省略了秒位
new Crontab('50 7 * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
}
}
步驟二:設定進程隨 webman 啟動
開啟設定檔 config/process.php,新增以下設定:
return [
....其他設定此處省略....
'task' => [
'handler' => app\process\Task::class
],
];
步驟三:重新啟動 webman
注意:定時任務不會立即執行,所有定時任務要等到下一分鐘才會開始計時執行。
說明
crontab 並非非同步執行。例如在一個 task 進程中設定了 A、B 兩個計時器,皆為每秒執行一次,若 A 任務耗時 10 秒,則 B 必須等 A 執行完才能執行,導致 B 執行延遲。
若業務對時間間隔較敏感,應將這些敏感定時任務放到獨立進程執行,以免受其他定時任務影響。範例 config/process.php 設定如下:
return [
....其他設定此處省略....
'task1' => [
'handler' => process\Task1::class
],
'task2' => [
'handler' => process\Task2::class
],
];
將對時間敏感的定時任務放在 process/Task1.php 中,其餘定時任務放在 process/Task2.php 中。
更多 config/process.php 設定說明,請參考 自訂進程