更新:定时任务重新修改
This commit is contained in:
parent
cff7b38058
commit
3f154e5fb5
@ -36,7 +36,7 @@ class CatchCrontabCommand extends Command
|
|||||||
->addOption('pid', '-p', Option::VALUE_REQUIRED, 'you can send signal to the process of pid')
|
->addOption('pid', '-p', Option::VALUE_REQUIRED, 'you can send signal to the process of pid')
|
||||||
->addOption('static', '-s', Option::VALUE_REQUIRED, 'default static process number', 1)
|
->addOption('static', '-s', Option::VALUE_REQUIRED, 'default static process number', 1)
|
||||||
->addOption('dynamic', '-dy', Option::VALUE_REQUIRED, 'default dynamic process number', 10)
|
->addOption('dynamic', '-dy', Option::VALUE_REQUIRED, 'default dynamic process number', 10)
|
||||||
->addOption('interval', '-i', Option::VALUE_REQUIRED, 'interval/seconds', 60)
|
->addOption('interval', '-i', Option::VALUE_REQUIRED, 'interval/seconds', 5)
|
||||||
->setDescription('start catch crontab schedule');
|
->setDescription('start catch crontab schedule');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1 +1,95 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | CatchAdmin [Just Like ~ ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Copyright (c) 2017~{$year} http://catchadmin.com All rights reserved.
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Licensed ( https://github.com/yanwenwu/catch-admin/blob/master/LICENSE.txt )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Author: JaguarJack [ njphper@gmail.com ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
declare (strict_types=1);
|
||||||
|
|
||||||
|
namespace catchAdmin\monitor\command;
|
||||||
|
|
||||||
|
use catchAdmin\monitor\command\process\Process;
|
||||||
|
use catchAdmin\monitor\model\Crontab;
|
||||||
|
use Cron\CronExpression;
|
||||||
|
use think\console\Command;
|
||||||
|
use think\console\Input;
|
||||||
|
use think\console\Output;
|
||||||
|
use think\facade\Log;
|
||||||
|
|
||||||
|
class ScheduleCommand extends Command
|
||||||
|
{
|
||||||
|
protected $pid;
|
||||||
|
|
||||||
|
protected function configure()
|
||||||
|
{
|
||||||
|
// 指令配置
|
||||||
|
$this->setName('catch:schedule')
|
||||||
|
->setDescription('catch schedule');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function execute(Input $input, Output $output)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
foreach ($this->getExecuteAbleCommands() as $command) {
|
||||||
|
|
||||||
|
$process = new Process(function (Process $process) use ($command) {
|
||||||
|
$this->getConsole()->call($command);
|
||||||
|
$process->exit();
|
||||||
|
});
|
||||||
|
|
||||||
|
$process->start();
|
||||||
|
}
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
Log::error('CatchSchedule Error:' . $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取可执行任务
|
||||||
|
*
|
||||||
|
* @time 2021年01月17日
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\DbException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
protected function getExecuteAbleCommands()
|
||||||
|
{
|
||||||
|
$executeAbleCommands = [];
|
||||||
|
|
||||||
|
Crontab::where('status', Crontab::ENABLE)
|
||||||
|
->where('tactics', '<>', Crontab::EXECUTE_FORBIDDEN)
|
||||||
|
->select()
|
||||||
|
->each(function ($command) use (&$executeAbleCommands){
|
||||||
|
if ($command->tactics == Crontab::EXECUTE_IMMEDIATELY) {
|
||||||
|
$executeAbleCommands[] = $command->task;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
$can = date('Y-m-d H:i', CronExpression::factory(trim($command->cron))
|
||||||
|
->getNextRunDate(date('Y-m-d H:i:s'), 0, true)
|
||||||
|
->getTimestamp()) == date('Y-m-d H:i', time());
|
||||||
|
|
||||||
|
if ($can) {
|
||||||
|
// 如果任务只执行一次 之后禁用该任务
|
||||||
|
if ($command->tactics === Crontab::EXECUTE_ONCE) {
|
||||||
|
Crontab::where('id', $command->id)->update([
|
||||||
|
'status' => Crontab::DISABLE,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$executeAbleCommands[] = $command->task;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
|
||||||
|
return $executeAbleCommands;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1 +0,0 @@
|
|||||||
<?php
|
|
@ -116,7 +116,7 @@ trait RegisterSignal
|
|||||||
$process->exit();
|
$process->exit();
|
||||||
});
|
});
|
||||||
|
|
||||||
$process->start();
|
$process->start();
|
||||||
|
|
||||||
Process::alarm($this->interval);
|
Process::alarm($this->interval);
|
||||||
});
|
});
|
||||||
|
@ -121,7 +121,7 @@ trait Store
|
|||||||
{
|
{
|
||||||
$pidFile = config('catch.crontab.master_pid_file');
|
$pidFile = config('catch.crontab.master_pid_file');
|
||||||
|
|
||||||
if (!file_exists($pidFile)) {
|
if (!FileSystem::exists($pidFile)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ trait Store
|
|||||||
*/
|
*/
|
||||||
public function renderStatus()
|
public function renderStatus()
|
||||||
{
|
{
|
||||||
return file_get_contents(self::statusPath());
|
return FileSystem::sharedGet(self::statusPath());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user