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();