workerman/crontab
คำอธิบาย
workerman/crontab เป็นโปรแกรมงานตามเวลาที่สร้างขึ้นจาก workerman คล้ายกับ crontab ของ linux โดย workerman/crontab รองรับการตั้งเวลาที่ระดับวินาที
การใช้
workerman/crontabจำเป็นต้องตั้งค่าเขตเวลาของ php ให้ถูกต้อง มิฉะนั้นผลลัพธ์ที่ได้อาจไม่ตรงตามที่คาดหวัง
คำอธิบายเวลา
0 1 2 3 4 5
| | | | | |
| | | | | +------ วันในสัปดาห์ (0 - 6) (อาทิตย์=0)
| | | | +------ เดือน (1 - 12)
| | | +-------- วันในเดือน (1 - 31)
| | +---------- ชั่วโมง (0 - 23)
| +------------ นาที (0 - 59)
+-------------- วินาที (0-59) [สามารถละเว้นได้ หากไม่มีตำแหน่ง 0 จะมีความละเอียดเวลาต่ำสุดเป็นนาที]
การติดตั้ง
composer require workerman/crontab
ตัวอย่าง
<?php
use Workerman\Worker;
require __DIR__ . '/vendor/autoload.php';
use Workerman\Crontab\Crontab;
$worker = new Worker();
// ตั้งค่าเขตเวลาเพื่อหลีกเลี่ยงผลลัพธ์ที่ไม่ตรงตามที่คาดหวัง
date_default_timezone_set('PRC');
$worker->onWorkerStart = function () {
// ทำงานในวินาทีที่ 1 ของทุกนาที
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";
});
};
Worker::runAll();
หมายเหตุ
งานตามเวลาไม่ได้ถูกดำเนินการในทันที งานทั้งหมดจะเริ่มนับเวลาในนาทีถัดไป
เช่นเดียวกับตัวตั้งเวลาของ workerman งานทั้งหมดจะถูกดำเนินการในกระบวนการปัจจุบัน
หากไม่มีการเปิดใช้งาน swoole/swow coroutine หากงานยังไม่เสร็จสิ้นก่อนที่จะถึงรอบถัดไป ระบบจะรอให้เสร็จสิ้นก่อน งานใหม่จะถูกดำเนินการช้าลง
หากเปิดใช้งาน swoole/swow coroutine หากงานก่อนหน้ายังไม่เสร็จ งานถัดไปอาจจะถูกดำเนินการทันทีโดยไม่ต้องรอ
อินเตอร์เฟส
Crontab::destroy()
ทำลายตัวตั้งเวลา
$crontab = new Crontab('1 * * * * *', function(){
echo date('Y-m-d H:i:s')."\n";
});
$crontab->destroy();