HAProxy 有一个非常好的状态页面,显示后端哪些网络服务器已启动,哪些已关闭。我正在尝试调试一些问题,需要知道 nginx 认为哪些服务器已启动,哪些服务器已关闭。有没有可以为 nginx 配置的网页或其他东西,这样当我需要此类信息时我可以点击一个 url?
谢谢,院长
HAProxy 有一个非常好的状态页面,显示后端哪些网络服务器已启动,哪些已关闭。我正在尝试调试一些问题,需要知道 nginx 认为哪些服务器已启动,哪些服务器已关闭。有没有可以为 nginx 配置的网页或其他东西,这样当我需要此类信息时我可以点击一个 url?
谢谢,院长
您可能需要检查几个模块:
不幸的是,开箱即用几乎是不可能的。vanila nginx 在设计上没有针对上游的全局状态,因此此信息对于每个工作进程都是本地的。
看看这个模块似乎对你有用http://wiki.nginx.org/NginxHttpHealthcheckModule
这个回复晚了一年,但 nginx 的 ustats 模块看起来非常令人印象深刻:
https://code.google.com/p/ustats/
移至 github https://github.com/0xc0dec/ustats
不幸的是,在 1.2 之后似乎没有维护,但可能仍然有效。
找到一个维护的叉子https://github.com/nginx-modules/ngx_ustats_module
1.7.2 补丁仍然可以完美地对抗 1.7.4
我一直在寻找 Amazon ELB 提供的简单健康检查。能够在 LB 中添加实例,具有健康检查机制以移除故障实例。
所以这是我的选择。
Nginx 还免费提供被动健康检查。它完全符合我的要求,没有花哨的监控,没有重量,没有花哨的路线检查。它会 ping 服务器并检查 200 状态响应。它将以循环方式进行。
fail_timeout 参数设置指定次数的失败尝试应该发生并且仍然认为服务器不可用的时间。换句话说,服务器在 fail_timeout 设置的时间间隔内不可用。
max_fails 参数设置在指定时间内仍认为服务器不可用的失败尝试次数。
例如:
upstream search { server 192.168.215.43:9200 max_fails=3 fail_timeout=10s; server 192.168.171.66:9200 max_fails=3 fail_timeout=10s; }