参考: 


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 可以简单的查看后端服务器的运行状态

 

wKiom1ZxItyB_CAZAACDMGnW_BQ471.jpg


可以看到当前两台服务器都运行正常(状态为 up)

 

下面关闭 tomcat1,等待 30 秒后,再查看状态,可以看到 tomcat1 状态已经更新为 DOWN

 

wKioL1ZxI_XzStdSAACEf3cdX7M860.jpg


再次打开 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 版本较老,则会提示不识别该命令;