2022-03-15 18:05:33 +08:00
|
|
|
|
<?php
|
2021-01-20 16:11:04 +08:00
|
|
|
|
|
2022-03-15 18:05:33 +08:00
|
|
|
|
declare(strict_types=1);
|
2021-01-20 16:11:04 +08:00
|
|
|
|
|
2022-08-01 16:31:54 +08:00
|
|
|
|
namespace ZM\Process;
|
2021-01-20 16:11:04 +08:00
|
|
|
|
|
2022-05-14 23:43:15 +08:00
|
|
|
|
use ZM\Exception\ZMKnownException;
|
2022-08-01 16:31:54 +08:00
|
|
|
|
use ZM\Store\FileSystem;
|
2021-03-24 23:34:46 +08:00
|
|
|
|
|
2022-08-01 16:31:54 +08:00
|
|
|
|
class ProcessStateManager
|
2021-01-20 16:11:04 +08:00
|
|
|
|
{
|
2022-08-22 20:54:14 +08:00
|
|
|
|
public static array $process_mode = [];
|
2022-05-14 23:43:15 +08:00
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @param null|int|string $id_or_name
|
|
|
|
|
|
* @throws ZMKnownException
|
|
|
|
|
|
* @internal
|
|
|
|
|
|
*/
|
|
|
|
|
|
public static function removeProcessState(int $type, $id_or_name = null)
|
|
|
|
|
|
{
|
|
|
|
|
|
switch ($type) {
|
|
|
|
|
|
case ZM_PROCESS_MASTER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/master.json';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
if (file_exists($file)) {
|
|
|
|
|
|
unlink($file);
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_MANAGER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/manager.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
if (file_exists($file)) {
|
|
|
|
|
|
unlink($file);
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_WORKER:
|
|
|
|
|
|
if (!is_int($id_or_name)) {
|
|
|
|
|
|
throw new ZMKnownException('E99999', 'worker_id必须为整数');
|
|
|
|
|
|
}
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/worker.' . $id_or_name . '.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
if (file_exists($file)) {
|
|
|
|
|
|
unlink($file);
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_USER:
|
|
|
|
|
|
if (!is_string($id_or_name)) {
|
|
|
|
|
|
throw new ZMKnownException('E99999', 'process_name必须为字符串');
|
|
|
|
|
|
}
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/user.' . $id_or_name . '.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
if (file_exists($file)) {
|
|
|
|
|
|
unlink($file);
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_TASKWORKER:
|
|
|
|
|
|
if (!is_int($id_or_name)) {
|
|
|
|
|
|
throw new ZMKnownException('E99999', 'worker_id必须为整数');
|
|
|
|
|
|
}
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/taskworker.' . $id_or_name . '.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
if (file_exists($file)) {
|
|
|
|
|
|
unlink($file);
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 用于框架内部获取多进程运行状态的函数
|
|
|
|
|
|
*
|
|
|
|
|
|
* @param mixed $id_or_name
|
|
|
|
|
|
* @throws ZMKnownException
|
|
|
|
|
|
* @return false|int|mixed
|
|
|
|
|
|
* @internal
|
|
|
|
|
|
*/
|
|
|
|
|
|
public static function getProcessState(int $type, $id_or_name = null)
|
|
|
|
|
|
{
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR;
|
2022-05-14 23:43:15 +08:00
|
|
|
|
switch ($type) {
|
|
|
|
|
|
case ZM_PROCESS_MASTER:
|
|
|
|
|
|
if (!file_exists($file . '/master.json')) {
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
$json = json_decode(file_get_contents($file . '/master.json'), true);
|
|
|
|
|
|
if ($json !== null) {
|
|
|
|
|
|
return $json;
|
|
|
|
|
|
}
|
|
|
|
|
|
return false;
|
|
|
|
|
|
case ZM_PROCESS_MANAGER:
|
|
|
|
|
|
if (!file_exists($file . '/manager.pid')) {
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
return intval(file_get_contents($file . '/manager.pid'));
|
|
|
|
|
|
case ZM_PROCESS_WORKER:
|
|
|
|
|
|
if (!is_int($id_or_name)) {
|
|
|
|
|
|
throw new ZMKnownException('E99999', 'worker_id必须为整数');
|
|
|
|
|
|
}
|
|
|
|
|
|
if (!file_exists($file . '/worker.' . $id_or_name . '.pid')) {
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
return intval(file_get_contents($file . '/worker.' . $id_or_name . '.pid'));
|
|
|
|
|
|
case ZM_PROCESS_USER:
|
|
|
|
|
|
if (!is_string($id_or_name)) {
|
|
|
|
|
|
throw new ZMKnownException('E99999', 'process_name必须为字符串');
|
|
|
|
|
|
}
|
|
|
|
|
|
if (!file_exists($file . '/user.' . $id_or_name . '.pid')) {
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
return intval(file_get_contents($file . '/user.' . $id_or_name . '.pid'));
|
|
|
|
|
|
case ZM_PROCESS_TASKWORKER:
|
|
|
|
|
|
if (!is_int($id_or_name)) {
|
|
|
|
|
|
throw new ZMKnownException('E99999', 'worker_id必须为整数');
|
|
|
|
|
|
}
|
|
|
|
|
|
if (!file_exists($file . '/taskworker.' . $id_or_name . '.pid')) {
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
return intval(file_get_contents($file . '/taskworker.' . $id_or_name . '.pid'));
|
|
|
|
|
|
default:
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 将各进程的pid写入文件,以备后续崩溃及僵尸进程处理使用
|
|
|
|
|
|
*
|
|
|
|
|
|
* @param int|string $pid
|
|
|
|
|
|
* @internal
|
|
|
|
|
|
*/
|
|
|
|
|
|
public static function saveProcessState(int $type, $pid, array $data = [])
|
|
|
|
|
|
{
|
|
|
|
|
|
switch ($type) {
|
|
|
|
|
|
case ZM_PROCESS_MASTER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/master.json';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
$json = [
|
|
|
|
|
|
'pid' => intval($pid),
|
|
|
|
|
|
'stdout' => $data['stdout'],
|
|
|
|
|
|
'daemon' => $data['daemon'],
|
|
|
|
|
|
];
|
|
|
|
|
|
file_put_contents($file, json_encode($json, JSON_UNESCAPED_UNICODE));
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_MANAGER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/manager.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
file_put_contents($file, strval($pid));
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_WORKER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/worker.' . $data['worker_id'] . '.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
file_put_contents($file, strval($pid));
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_USER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/user.' . $data['process_name'] . '.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
file_put_contents($file, strval($pid));
|
|
|
|
|
|
return;
|
|
|
|
|
|
case ZM_PROCESS_TASKWORKER:
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$file = ZM_PID_DIR . '/taskworker.' . $data['worker_id'] . '.pid';
|
2022-05-14 23:43:15 +08:00
|
|
|
|
file_put_contents($file, strval($pid));
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static function isStateEmpty(): bool
|
|
|
|
|
|
{
|
2022-08-01 16:31:54 +08:00
|
|
|
|
$ls = FileSystem::scanDirFiles(ZM_PID_DIR, false, true);
|
2022-05-14 23:43:15 +08:00
|
|
|
|
return empty($ls);
|
|
|
|
|
|
}
|
2022-03-15 18:05:33 +08:00
|
|
|
|
}
|