Files
kiri-core/System/Crontab/Consumer.php
T

108 lines
2.4 KiB
PHP
Raw Normal View History

2021-03-26 01:01:21 +08:00
<?php
namespace Snowflake\Crontab;
use Exception;
use Snowflake\Event;
use Snowflake\Process\Process;
use Snowflake\Snowflake;
2021-03-26 01:39:22 +08:00
use Swoole\Coroutine;
2021-03-26 01:01:21 +08:00
/**
* Class Consumer
* @package Snowflake\Crontab
*/
class Consumer extends Process
{
2021-03-26 01:39:22 +08:00
public Coroutine\Channel $channel;
2021-03-26 01:01:21 +08:00
/**
* @param \Swoole\Process $process
*/
public function onHandler(\Swoole\Process $process): void
{
$process->name('Crontab consumer');
2021-03-26 01:39:22 +08:00
$this->channel = new Coroutine\Channel(2000);
2021-03-26 01:42:15 +08:00
go(function () {
2021-03-26 01:39:22 +08:00
$this->popChannel();
});
$this->tick($process);
}
/**
* @throws Exception
*/
public function popChannel()
{
2021-03-26 01:47:24 +08:00
/** @var Crontab $crontab */
2021-03-26 01:39:22 +08:00
$crontab = $this->channel->pop(-1);
2021-03-26 01:44:57 +08:00
go(function () use ($crontab) {
2021-03-26 01:47:24 +08:00
try {
$crontab->increment()->execute();
if ($crontab->getExecuteNumber() < $crontab->getMaxExecuteNumber()) {
Consumer::addTask($crontab);
} else if ($crontab->isLoop()) {
Consumer::addTask($crontab);
}
} catch (\Throwable $throwable) {
$this->application->addError($throwable->getMessage());
} finally {
fire(Event::SYSTEM_RESOURCE_RELEASES);
}
2021-03-26 01:44:57 +08:00
});
2021-03-26 01:39:22 +08:00
$this->popChannel();
}
/**
* @param \Swoole\Process $process
* @throws \ReflectionException
* @throws \Snowflake\Exception\ComponentException
* @throws \Snowflake\Exception\ConfigException
* @throws \Snowflake\Exception\NotFindClassException
*/
public function tick(\Swoole\Process $process)
{
2021-03-26 02:07:05 +08:00
$value = $process->read(40);
2021-03-26 01:39:22 +08:00
$redis = Snowflake::app()->getRedis();
2021-03-26 01:01:21 +08:00
2021-03-26 01:39:22 +08:00
$crontab = swoole_unserialize($redis->get($value));
$redis->del($value);
if (is_object($crontab)) {
$this->channel->push($crontab);
2021-03-26 01:01:21 +08:00
}
2021-03-26 01:39:22 +08:00
$redis->release();
$this->tick($process);
2021-03-26 01:01:21 +08:00
}
/**
* @param Crontab $crontab
* @throws Exception
*/
2021-03-26 01:47:24 +08:00
private static function addTask(Crontab $crontab)
2021-03-26 01:01:21 +08:00
{
$redis = Snowflake::app()->getRedis();
$name = md5($crontab->getName());
$redis->set('crontab:' . $name, swoole_serialize($crontab));
$tickTime = time() + $crontab->getTickTime();
$redis->zAdd(Producer::CRONTAB_KEY, $tickTime, $crontab->getName());
}
}