Hyperf 重启时 AMQP 报错:如何排查并解决 Broken Pipe 异常?

Hyperf 重启时 AMQP 报错:如何排查并解决 Broken Pipe 异常?

hyperf 重启时 amqp 异常处理

在重启 hyperf 时,可能会遇到 amqp 报出异常的情况。这可能是由于两种重启方式造成的:

  • 通过 systemctl 脚本
  • 通过 PHP bin/hyperf server:watcher

异常信息如下:

[WARNING] Recv loop broken. The reason is PhpAmqpLibExceptionAMQPConnectionClosedException: Broken pipe or closed connection in /data/web/website/hyperf-skeleton/vendor/php-amqplib/php-amqplib/PhpAmqpLib/Connection/AbstractConnection.php:571
登录后复制

这是因为服务关闭导致 mq 服务端关闭了连接。

解决方案:

遇到这个异常后,如果影响了服务的正常运行,可以采取以下措施:

  • 重新启动 amqp 服务
  • 检查 hyperf 配置文件中的 amqp 设置是否正确

但是,需要注意的是,这个异常通常是 warning(警告)级别的,而非 fatal/Error(异常)。这意味着它不会影响服务的正常运行。因此,如果服务未受到影响,可以忽略这个警告。

© 版权声明
THE END
喜欢就支持一下吧
点赞10 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容