更改 命令
This commit is contained in:
parent
c6a10b962f
commit
51b7451de2
@ -6,14 +6,14 @@
|
||||
use Illuminate\Console\Command;
|
||||
use Symfony\Component\Console\Command\Command as CommandAlias;
|
||||
|
||||
class Log extends Command
|
||||
class Monitor extends Command
|
||||
{
|
||||
/**
|
||||
* The name and signature of the console command.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $signature = 'cluster:log';
|
||||
protected $signature = 'monitor {--ignore_event=}';
|
||||
|
||||
/**
|
||||
* The console command description.
|
||||
@ -29,7 +29,19 @@ class Log extends Command
|
||||
*/
|
||||
public function handle(): int
|
||||
{
|
||||
ClusterSupport::listen('*', function ($event, $message) {
|
||||
$ignore_events = [];
|
||||
|
||||
if ($this->option('ignore_event')) {
|
||||
$ignore_events = explode(',', $this->option('ignore_event'));
|
||||
}
|
||||
|
||||
ClusterSupport::publish('monitor.started');
|
||||
|
||||
ClusterSupport::listen('*', function ($event, $message) use ($ignore_events) {
|
||||
if (in_array($event, $ignore_events)) {
|
||||
return;
|
||||
}
|
||||
|
||||
$this->format($event, $message);
|
||||
}, false);
|
||||
|
||||
@ -52,8 +64,9 @@ private function format(string $event, array $message = [])
|
||||
public function switch($event, $message = []): string|null
|
||||
{
|
||||
$events = [
|
||||
'monitor.started' => '我正在监听集群消息。',
|
||||
'node.ok' => '此节点初始化成功,并且已经加入集群。',
|
||||
'node.online' => '此节点已经上线。',
|
||||
'node.online' => fn($message) => '此节点已经上线,启动权重为:' . $message['weight'],
|
||||
'node.offline' => '将不再处理任何任务。',
|
||||
'cluster_ready.ok' => 'ClusterSupport Ready 就绪了,已经可以处理请求了。',
|
||||
'config.updated' => '集群配置文件已经更新,请所有 slave 节点下载。',
|
||||
@ -71,6 +84,7 @@ public function switch($event, $message = []): string|null
|
||||
'cluster.deployed.ok' => '集群配置文件部署成功。',
|
||||
'http.incoming' => fn($message) => $this->handleIncomingRequest($message),
|
||||
'http.outgoing' => fn($message) => $this->handleOutgoingRequest($message),
|
||||
'weight.updated' => fn($message) => $this->handleWeightUpdated($message),
|
||||
];
|
||||
|
||||
$resp = $events[$event] ?? null;
|
||||
@ -101,6 +115,18 @@ private function handleOutgoingRequest(array $message): string
|
||||
return $msg;
|
||||
}
|
||||
|
||||
private function handleWeightUpdated(array $message): string
|
||||
{
|
||||
$msg = '';
|
||||
if ($message['weight'] === "0") {
|
||||
$msg .= '我不参与调度了。';
|
||||
} else {
|
||||
$msg .= '我的权重是:' . $message['weight'] . '。';
|
||||
}
|
||||
|
||||
return $msg;
|
||||
}
|
||||
|
||||
private function appendUser(array $message): string
|
||||
{
|
||||
$msg = '';
|
Loading…
Reference in New Issue
Block a user