Skip to content

Commit

Permalink
chore(healthcheck) apply suggestions from #112
Browse files Browse the repository at this point in the history
  • Loading branch information
locao committed Jul 6, 2022
1 parent 53b50b9 commit 19274c1
Showing 1 changed file with 17 additions and 10 deletions.
27 changes: 17 additions & 10 deletions lib/resty/healthcheck.lua
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ local cjson = require("cjson.safe").new()
local table_insert = table.insert
local table_remove = table.remove
local worker_events = require("resty.worker.events")
-- local resty_lock = require("resty.lock") -- required later in the file"
local re_find = ngx.re.find
local bit = require("bit")
local ngx_now = ngx.now
Expand Down Expand Up @@ -217,6 +218,14 @@ end

local run_locked
do
-- resty_lock is restricted to this scope in order to keep sensitive
-- lock-handling code separate separate from all other business logic
--
-- If you need to use resty_lock in a way that is not covered by the
-- `run_locked` helper function defined below, it's strongly-advised to
-- define it fully within this scope unless you have a very good reason
--
-- (see https://github.com/Kong/lua-resty-healthcheck/pull/112)
local resty_lock = require "resty.lock"

local yieldable = {
Expand Down Expand Up @@ -260,7 +269,7 @@ do
-- attempt to sleep/yield
-- 2. If acquiring the lock fails due to a timeout, `run_locked`
-- (this function) is re-scheduled to run in a timer. In this case,
-- the function returns `nil, "scheduled"`
-- the function returns `"scheduled"`
--
-- @param self The checker object
-- @param key the key/identifier to acquire a lock for
Expand Down Expand Up @@ -301,12 +310,12 @@ do

if not elapsed and err == "timeout" and not yield then
-- yielding is not possible in the current phase, so retry in a timer
local _, terr = schedule(run_locked, self, key, fn, ...)
if terr ~= nil then
local ok, terr = schedule(run_locked, self, key, fn, ...)
if not ok then
return nil, terr
end

return nil, "scheduled"
return "scheduled"

elseif not elapsed then
return nil, "failed acquiring lock for '" .. key .. "', " .. err
Expand All @@ -322,9 +331,9 @@ do

if not pok then
return nil, perr
else
return perr, res
end

return perr, res
end
end
local checker = {}
Expand Down Expand Up @@ -368,9 +377,8 @@ end
local function locking_target_list(self, fn)
local ok, err = run_locked(self, self.TARGET_LIST_LOCK, with_target_list, self, fn)

if not ok and err == "scheduled" then
if ok == "scheduled" then
self:log(DEBUG, "target_list function re-scheduled in timer")
ok = true
end

return ok, err
Expand Down Expand Up @@ -624,9 +632,8 @@ local function locking_target(self, ip, port, hostname, fn)

local ok, err = run_locked(self, key, fn)

if not ok and err == "scheduled" then
if ok == "scheduled" then
self:log(DEBUG, "target function for ", key, " was re-scheduled")
ok = true
end

return ok, err
Expand Down

0 comments on commit 19274c1

Please sign in to comment.