2021-01-04 18:21:37 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace Snowflake;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
use Exception;
|
|
|
|
|
use HttpServer\IInterface\Task;
|
2021-03-19 17:09:52 +08:00
|
|
|
use ReflectionException;
|
2021-01-04 18:21:37 +08:00
|
|
|
use Snowflake\Abstracts\Component;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Class Async
|
|
|
|
|
* @package Snowflake
|
|
|
|
|
*/
|
|
|
|
|
class Async extends Component
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
2021-05-07 17:06:10 +08:00
|
|
|
private static array $_absences = [];
|
2021-04-24 20:17:55 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $name
|
|
|
|
|
* @param Task $handler
|
|
|
|
|
*/
|
|
|
|
|
public function addAsync(string $name, Task $handler)
|
|
|
|
|
{
|
2021-05-07 17:06:10 +08:00
|
|
|
static::$_absences[$name] = $handler::class;
|
2021-04-24 20:17:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $name
|
|
|
|
|
* @param array $params
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
public function dispatch(string $name, array $params = [])
|
|
|
|
|
{
|
|
|
|
|
$server = Snowflake::app()->getSwoole();
|
|
|
|
|
if (!isset($server->setting['task_worker_num'])) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-07 17:06:10 +08:00
|
|
|
if (!isset(static::$_absences[$name])) {
|
2021-04-24 20:17:55 +08:00
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/** @var Task $class */
|
2021-05-07 17:06:10 +08:00
|
|
|
$class = Snowflake::createObject(static::$_absences[$name]);
|
2021-04-24 20:17:55 +08:00
|
|
|
$class->setParams($params);
|
|
|
|
|
|
|
|
|
|
$randWorkerId = random_int(0, $server->setting['task_worker_num'] - 1);
|
|
|
|
|
|
2021-04-24 20:34:35 +08:00
|
|
|
$server->task(serialize($class), $randWorkerId);
|
2021-04-24 20:17:55 +08:00
|
|
|
}
|
2021-01-04 18:21:37 +08:00
|
|
|
|
|
|
|
|
}
|