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-16 00:22:26 +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)
|
|
|
|
|
{
|
2021-04-23 03:25:03 +08:00
|
|
|
match ($swollen_universalize['action'] ?? null) {
|
|
|
|
|
'kafka' => $this->onKafkaWorker($swollen_universalize),
|
|
|
|
|
'crontab' => $this->onCrontabWorker($swollen_universalize),
|
|
|
|
|
default => $this->onMessageWorker($server, $src_worker_id, $swollen_universalize)
|
|
|
|
|
};
|
2021-04-16 00:22:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param array $message
|
|
|
|
|
* @return string
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
private function onCrontabWorker(array $message): string
|
|
|
|
|
{
|
2021-04-24 00:23:15 +08:00
|
|
|
if (empty($message['handler'] ?? null)) {
|
2021-04-16 00:22:26 +08:00
|
|
|
throw new Exception('unknown handler');
|
|
|
|
|
}
|
|
|
|
|
/** @var Crontab $handler */
|
2021-04-24 20:06:21 +08:00
|
|
|
$handler = $message['handler'];
|
2021-04-24 00:21:18 +08:00
|
|
|
defer(function () use ($handler) {
|
|
|
|
|
$return = $handler->isRecover();
|
|
|
|
|
if ($return === 999) {
|
|
|
|
|
$name = $handler->getName();
|
|
|
|
|
|
|
|
|
|
$redis = Snowflake::app()->getRedis();
|
|
|
|
|
if ($redis->exists('stop:crontab:' . $name)) {
|
|
|
|
|
$redis->del('crontab:' . $name);
|
|
|
|
|
$redis->del('stop:crontab:' . $name);
|
|
|
|
|
} else {
|
|
|
|
|
$redis->set('crontab:' . $name, swoole_serialize($handler));
|
|
|
|
|
$tickTime = time() + $handler->getTickTime();
|
|
|
|
|
$redis->zAdd(Producer::CRONTAB_KEY, $tickTime, $name);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
2021-04-16 00:22:26 +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'];
|
|
|
|
|
|
2021-04-24 20:46:17 +08:00
|
|
|
call_user_func($message['handler'], new Struct($topic, $rdMessage));
|
2021-04-16 00:22:26 +08:00
|
|
|
|
|
|
|
|
return 'success';
|
|
|
|
|
}
|
2021-04-11 17:18:54 +08:00
|
|
|
|
|
|
|
|
|
2020-08-31 01:27:08 +08:00
|
|
|
}
|