Files
kiri-core/HttpServer/Events/OnPipeMessage.php
T

102 lines
2.2 KiB
PHP
Raw Normal View History

2020-08-31 01:27:08 +08:00
<?php
2020-10-29 18:17:25 +08:00
declare(strict_types=1);
2020-08-31 01:27:08 +08:00
2020-09-02 11:38:47 +08:00
namespace HttpServer\Events;
2020-08-31 01:27:08 +08:00
2020-09-02 17:02:13 +08:00
use Exception;
2020-09-04 01:05:33 +08:00
use HttpServer\Abstracts\Callback;
2021-04-11 17:18:54 +08:00
use Kafka\Struct;
2021-04-12 11:05:57 +08:00
use Snowflake\Crontab\Crontab;
2021-04-24 00:21:18 +08:00
use Snowflake\Crontab\Producer;
2020-09-02 17:02:13 +08:00
use Snowflake\Event;
2021-04-24 00:21:18 +08:00
use Snowflake\Snowflake;
2020-09-02 17:02:13 +08:00
use Swoole\Server;
2020-08-31 01:27:08 +08:00
2020-09-02 17:02:13 +08:00
/**
* Class OnPipeMessage
* @package HttpServer\Events
*/
2020-08-31 01:27:08 +08:00
class OnPipeMessage extends Callback
{
2021-04-26 17:34:33 +08:00
/**
* @param Server $server
* @param int $src_worker_id
* @param $swollen_universalize
* @throws Exception
*/
public function onHandler(Server $server, int $src_worker_id, $swollen_universalize)
{
match ($swollen_universalize['action'] ?? null) {
'kafka' => $this->onKafkaWorker($swollen_universalize),
'crontab' => $this->onCrontabWorker($swollen_universalize),
default => $this->onMessageWorker($server, $src_worker_id, $swollen_universalize)
};
}
/**
* @param array $message
* @return string
* @throws Exception
*/
private function onCrontabWorker(array $message): string
{
if (empty($message['handler'] ?? null)) {
throw new Exception('unknown handler');
}
/** @var Crontab $handler */
2021-04-28 11:57:49 +08:00
$handler = $message['handler'];
2021-04-28 11:56:19 +08:00
defer(function () use ($handler) {
if ($handler->isRecover() !== 999) {
return;
}
$redis = Snowflake::app()->getRedis();
$name = $handler->getName();
if (!$redis->exists('stop:crontab:' . $name)) {
$redis->set('crontab:' . $name, swoole_serialize($handler));
$tickTime = time() + $handler->getTickTime();
$redis->zAdd(Producer::CRONTAB_KEY, $tickTime, $name);
} else {
$redis->del('crontab:' . $name);
$redis->del('stop:crontab:' . $name);
}
});
2021-04-26 17:34:33 +08:00
$handler->increment()->execute();
return 'success';
}
/**
* @param $server
* @param $src_worker_id
* @param $message
* @return string
* @throws Exception
*/
private function onMessageWorker($server, $src_worker_id, $message): string
{
fire(Event::PIPE_MESSAGE, [$server, $src_worker_id, $message]);
return 'success';
}
/**
* @param array $message
* @return string
*/
private function onKafkaWorker(array $message): string
{
[$topic, $rdMessage] = $message['body'];
call_user_func($message['handler'], new Struct($topic, $rdMessage));
return 'success';
}
2021-04-11 17:18:54 +08:00
2020-08-31 01:27:08 +08:00
}