Skip to content

Commit

Permalink
fix(hostname) use IP if hostname is not provided #48
Browse files Browse the repository at this point in the history
  • Loading branch information
Matthew Silverman authored and Tieske committed Sep 18, 2020
1 parent a814617 commit fc5a75c
Show file tree
Hide file tree
Showing 2 changed files with 119 additions and 8 deletions.
16 changes: 8 additions & 8 deletions lib/resty/healthcheck.lua
Original file line number Diff line number Diff line change
Expand Up @@ -842,7 +842,7 @@ function checker:run_single_check(ip, port, hostname, hostheader)
end
if not session then
sock:close()
self:log(ERR, "failed SSL handshake with '", hostname, " (", ip, ":", port, ")': ", err)
self:log(ERR, "failed SSL handshake with '", hostname or "", " (", ip, ":", port, ")': ", err)
return self:report_tcp_failure(ip, port, hostname, "connect", "active")
end

Expand All @@ -854,7 +854,7 @@ function checker:run_single_check(ip, port, hostname, hostheader)
local bytes
bytes, err = sock:send(request)
if not bytes then
self:log(ERR, "failed to send http request to '", hostname, " (", ip, ":", port, ")': ", err)
self:log(ERR, "failed to send http request to '", hostname or "", " (", ip, ":", port, ")': ", err)
if err == "timeout" then
sock:close() -- timeout errors do not close the socket.
return self:report_timeout(ip, port, hostname, "active")
Expand All @@ -865,7 +865,7 @@ function checker:run_single_check(ip, port, hostname, hostheader)
local status_line
status_line, err = sock:receive()
if not status_line then
self:log(ERR, "failed to receive status line from '", hostname, " (",ip, ":", port, ")': ", err)
self:log(ERR, "failed to receive status line from '", hostname or "", " (",ip, ":", port, ")': ", err)
if err == "timeout" then
sock:close() -- timeout errors do not close the socket.
return self:report_timeout(ip, port, hostname, "active")
Expand All @@ -880,21 +880,21 @@ function checker:run_single_check(ip, port, hostname, hostheader)
if from then
status = tonumber(status_line:sub(from, to))
else
self:log(ERR, "bad status line from '", hostname, " (", ip, ":", port, ")': ", status_line)
self:log(ERR, "bad status line from '", hostname or "", " (", ip, ":", port, ")': ", status_line)
-- note: 'status' will be reported as 'nil'
end

sock:close()

self:log(DEBUG, "Reporting '", hostname, " (", ip, ":", port, ")' (got HTTP ", status, ")")
self:log(DEBUG, "Reporting '", hostname or "", " (", ip, ":", port, ")' (got HTTP ", status, ")")

return self:report_http_status(ip, port, hostname, status, "active")
end

-- executes a work package (a list of checks) sequentially
function checker:run_work_package(work_package)
for _, work_item in ipairs(work_package) do
self:log(DEBUG, "Checking ", work_item.hostname, " ",
self:log(DEBUG, "Checking ", work_item.hostname or "", " ",
work_item.hostheader and "(host header: ".. work_item.hostheader .. ")"
or "", work_item.ip, ":", work_item.port,
" (currently ", work_item.debug_health, ")")
Expand Down Expand Up @@ -1034,7 +1034,7 @@ function checker:event_handler(event_name, ip, port, hostname)
if event_name == self.events.remove then
if target_found then
-- remove hash part
self.targets[target_found.ip][target_found.port][target_found.hostname] = nil
self.targets[target_found.ip][target_found.port][target_found.hostname or target_found.ip] = nil
if not next(self.targets[target_found.ip][target_found.port]) then
-- no more hostnames on this port, so delete it
self.targets[target_found.ip][target_found.port] = nil
Expand Down Expand Up @@ -1415,7 +1415,7 @@ function _M.new(opts)
-- fill-in the hash part for easy lookup
self.targets[target.ip] = self.targets[target.ip] or {}
self.targets[target.ip][target.port] = self.targets[target.ip][target.port] or {}
self.targets[target.ip][target.port][target.hostname] = target
self.targets[target.ip][target.port][target.hostname or target.ip] = target
end

return true
Expand Down
111 changes: 111 additions & 0 deletions t/18-event_handler.t
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
use Test::Nginx::Socket::Lua;
use Cwd qw(cwd);

workers(1);

plan tests => repeat_each() * 4;

my $pwd = cwd();

our $HttpConfig = qq{
lua_package_path "$pwd/lib/?.lua;;";
lua_shared_dict test_shm 8m;
lua_shared_dict my_worker_events 8m;
};

run_tests();

__DATA__

=== TEST 1: add_target() without hostname, remove_target() with same ip:port
--- http_config eval
qq{
$::HttpConfig

server {
listen 2112;
location = /status {
return 200;
}
}
}
--- config
location = /t {
content_by_lua_block {
local we = require "resty.worker.events"
assert(we.configure{ shm = "my_worker_events", interval = 0.1 })
local healthcheck = require("resty.healthcheck")
local checker = healthcheck.new({
name = "testing",
shm_name = "test_shm",
checks = {
active = {
http_path = "/status",
healthy = {
interval = 0.1
},
unhealthy = {
interval = 0.1
}
}
}
})
ngx.sleep(0.2) -- wait twice the interval
local ok, err = checker:add_target("127.0.0.1", 2112)
ngx.say(ok)
ngx.sleep(0.2) -- wait twice the interval
ok, err = checker:remove_target("127.0.0.1", 2112)
ngx.sleep(0.2) -- wait twice the interval
}
}
--- request
GET /t
--- response_body
true

=== TEST 2: add_target() with hostname, remove_target() on same target
--- http_config eval
qq{
$::HttpConfig

server {
listen 2112;
location = /status {
return 200;
}
}
}
--- config
location = /t {
content_by_lua_block {
local we = require "resty.worker.events"
assert(we.configure{ shm = "my_worker_events", interval = 0.1 })
local healthcheck = require("resty.healthcheck")
local checker = healthcheck.new({
name = "testing",
shm_name = "test_shm",
checks = {
active = {
http_path = "/status",
healthy = {
interval = 0.1
},
unhealthy = {
interval = 0.1
}
}
}
})
ngx.sleep(0.2) -- wait twice the interval
local ok, err = checker:add_target("127.0.0.1", 2112, "localhost")
ngx.say(ok)
ngx.sleep(0.2) -- wait twice the interval
ok, err = checker:remove_target("127.0.0.1", 2112, "localhost")
ngx.sleep(0.2) -- wait twice the interval
}
}
--- request
GET /t
--- response_body
true

0 comments on commit fc5a75c

Please sign in to comment.