blob: 514a5c12ce2de2de49b3c9d0fdd73a5a91bab871 [file] [log] [blame]
--
-- Licensed to the Apache Software Foundation (ASF) under one or more
-- contributor license agreements. See the NOTICE file distributed with
-- this work for additional information regarding copyright ownership.
-- The ASF licenses this file to You under the Apache License, Version 2.0
-- (the "License"); you may not use this file except in compliance with
-- the License. You may obtain a copy of the License at
--
-- http://www.apache.org/licenses/LICENSE-2.0
--
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS,
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-- See the License for the specific language governing permissions and
-- limitations under the License.
--
local log = require("apisix.core.log")
local sleep = require("apisix.core.utils").sleep
local timer_every = ngx.timer.every
local timer_at = ngx.timer.at
local update_time = ngx.update_time
local now = ngx.now
local pcall = pcall
local _M = {
version = 0.1,
}
local function _internal(timer)
timer.start_time = now()
repeat
local ok, err = pcall(timer.callback_fun)
if not ok then
log.error("failed to run the timer: ", timer.name, " err: ", err)
if timer.sleep_fail > 0 then
sleep(timer.sleep_fail)
end
elseif timer.sleep_succ > 0 then
sleep(timer.sleep_succ)
end
update_time()
until timer.each_ttl <= 0 or now() >= timer.start_time + timer.each_ttl
end
local function run_timer(premature, self)
if self.running or premature then
return
end
self.running = true
local ok, err = pcall(_internal, self)
if not ok then
log.error("failed to run timer[", self.name, "] err: ", err)
end
self.running = false
end
function _M.new(name, callback_fun, opts)
if not name then
return nil, "missing argument: name"
end
if not callback_fun then
return nil, "missing argument: callback_fun"
end
opts = opts or {}
local timer = {
name = name,
each_ttl = opts.each_ttl or 1,
sleep_succ = opts.sleep_succ or 1,
sleep_fail = opts.sleep_fail or 5,
start_time = 0,
callback_fun = callback_fun,
running = false,
}
local hdl, err = timer_every(opts.check_interval or 1,
run_timer, timer)
if not hdl then
return nil, err
end
hdl, err = timer_at(0, run_timer, timer)
if not hdl then
return nil, err
end
return timer
end
return _M