参考:
- https://github.com/openresty/lua-resty-upstream-healthcheck
直接上配置示例步骤,配置环境如下:
在同一台服务器上配置了两个 tomcat 服务器作为 upstream 的两个节点,分别为:
tomcat1: 127.0.0.1:48080
tomcat2: 127.0.0.1:58080
然后分别在两个 tomcat 的 webapps/ROOT/ 下放置一个简单的文本文件 health.txt,如下:
/home/health/test/tomcat1/webapps/ROOT [health@healthvm ROOT]$ ll 总用量 200 -rw-r--r--. 1 health health 17811 12月 16 14:06 asf-logo.png -rw-r--r--. 1 health health 5866 12月 16 14:06 asf-logo-wide.gif -rw-r--r--. 1 health health 713 12月 16 14:06 bg-button.png -rw-r--r--. 1 health health 1918 12月 16 14:06 bg-middle.png -rw-r--r--. 1 health health 1392 12月 16 14:06 bg-nav-item.png -rw-r--r--. 1 health health 1401 12月 16 14:06 bg-nav.png -rw-r--r--. 1 health health 3103 12月 16 14:06 bg-upper.png -rw-r--r--. 1 health health 3376 12月 16 14:06 build.xml -rw-r--r--. 1 health health 21630 12月 16 14:06 favicon.ico -rw-rw-r--. 1 health health 14 12月 16 15:27 health.txt
health.txt 也是很简单的:
[health@healthvm ROOT]$ more health.txt
I am tomcat1.
nginx 配置 192.168.1.200:38080 提供反向代理服务,完整配置如下:
http {
#---------------------
# test health check
#---------------------
lua_package_path "/usr/local/openresty/lualib/resty/?.lua;/usr/local/openresty/lualib/resty/upstream/?.lua;;";
upstream tomcat {
server 127.0.0.1:48080;
server 127.0.0.1:58080;
}
lua_shared_dict healthcheck 1m;
lua_socket_log_errors off;
init_worker_by_lua_block {
local hc = require "resty.upstream.healthcheck"
local ok, err = hc.spawn_checker {
shm = "healthcheck",
upstream = "tomcat",
type = "http",
http_req = "GET /health.txt HTTP/1.0\r\nHost: tomcat\r\n\r\n",
interval = 2000,
timeout = 5000,
fall = 3,
rise = 2,
valid_statuses = {200, 302},
concurrency = 1,
}
if not ok then
ngx.log(ngx.ERR, "=======> failed to spawn health checker: ", err)
return
end
}
server {
listen 38080;
server_name localhost;
access_log logs/access-38080.log main;
error_log logs/error-38080.log debug;
location / {
proxy_pass http://tomcat;
}
location /server/status {
access_log off;
default_type text/plain;
content_by_lua_block {
local hc = require "resty.upstream.healthcheck"
ngx.say("Nginx Worker PID: ", ngx.worker.pid())
ngx.print(hc.status_page())
}
}
}
}
其中通过访问 http://192.168.1.200:38080/server/status 可以简单的查看后端服务器的运行状态
可以看到当前两台服务器都运行正常(状态为 up)
下面关闭 tomcat1,等待 30 秒后,再查看状态,可以看到 tomcat1 状态已经更新为 DOWN
再次打开 tomcat1 之后,状态又恢复为 UP 了。
注:
1,我这里测试时直接采用的是 openresty-1.9.3.2 版本,已经默认安装了 lua-resty-upstream-healthcheck 模块;
2, init_worker_by_lua_block 命令从 lua-nginx-module v0.9.17 版本开始支持,如果你的 lua-nginx-module 版本较老,则会提示不识别该命令;
转载于:https://blog.51cto.com/quietmadman/1725302