Swoole如何获取服务器的启动时间

答案:在Swoole中可通过WorkerStart事件记录主进程启动时间戳实现服务器启动时间查询功能。1. 在onWorkerStart中判断$workerId===0时记录time();2. 通过Request事件暴露/uptime接口返回启动时间和运行秒数;3. 推荐使用类静态属性封装 startTime 避免全局变量;4. 注意仅在主进程设置一次,可结合microtime(true)提升精度。

Swoole如何获取服务器的启动时间

在 Swoole 中,并没有直接提供获取服务器启动时间的内置方法,但可以通过记录服务启动时的时间戳来实现这一功能。最简单有效的方式是在主进程启动时(如 onWorkerStart 事件中判断是否为主进程)记录当前时间,之后通过自定义逻辑对外暴露这个时间。

1. 记录服务器启动时间

在创建 Swoole 服务时,可以在主进程的 Worker 启动回调中判断是否是主 Worker(通常为管理进程或主服务进程),然后保存时间戳:

 $server = new SwooleHttpServer("0.0.0.0", 9501); <p>// 定义一个全局变量或类属性来保存启动时间 $startTime = null;</p><p>$server->on('WorkerStart', function ($server, $workerId) use (&$startTime) { // 判断是否是主进程(通常是第一个 Worker,且 $workerId == 0) if ($workerId === 0) { $startTime = time(); echo "Server started at: " . date('Y-m-d H:i:s', $startTime) . "n"; } });</p><p>$server->on('Request', function ($request, $response) use (&$startTime) { if (isset($request->server['path_info']) && $request->server['path_info'] === '/uptime') { $bootTime = date('Y-m-d H:i:s', $startTime); $upSeconds = time() - $startTime; $response->end("Server Boot Time: {$bootTime}nUptime: {$upSeconds} secondsn"); return; } $response->end("Hello Swoole!"); });</p>

2. 提供接口查询启动时间

上面的例子中,当访问 /uptime 路径时,会返回服务器的启动时间和已运行秒数。你可以根据需要扩展成 JSON 格式或其他输出方式。

3. 使用类封装更清晰

在实际项目中,建议将启动时间保存在类的静态属性或配置管理器中,避免使用全局变量:

Swoole如何获取服务器的启动时间

美间AI

美间AI:让设计更简单

Swoole如何获取服务器的启动时间45

查看详情 Swoole如何获取服务器的启动时间

 class ServerMonitor {     public static $startTime; <pre class='brush:php;toolbar:false;'>public static function setStartTime($time) {     self::$startTime = $time; }  public static function getBootTime() {     return date('Y-m-d H:i:s', self::$startTime); }  public static function getUptime() {     return time() - self::$startTime; }

}

然后在 WorkerStart 中调用 ServerMonitor::setStartTime(time()) 即可。

4. 注意事项

  • 确保只在主 Worker 中记录一次时间,避免多个 Worker 覆盖或重复设置。
  • 若使用 Task 进程或多主进程架构,需更精确地判断进程类型(如检查 $server->isMaster$server->taskworker)。
  • 时间精度可根据需要使用 microtime(true) 获取毫秒级时间。

基本上就这些。通过手动记录启动时刻,就能轻松实现 Swoole 服务的启动时间查询功能。

js json swoole swoole 架构 json 封装 全局变量 接口 事件

上一篇
下一篇
text=ZqhQzanResources