aboutsummaryrefslogtreecommitdiffstats
path: root/lualib/lua_redis.lua
diff options
context:
space:
mode:
Diffstat (limited to 'lualib/lua_redis.lua')
-rw-r--r--lualib/lua_redis.lua36
1 files changed, 26 insertions, 10 deletions
diff --git a/lualib/lua_redis.lua b/lualib/lua_redis.lua
index 241a58ce1..615e4d871 100644
--- a/lualib/lua_redis.lua
+++ b/lualib/lua_redis.lua
@@ -1219,6 +1219,11 @@ local function is_all_servers_failed(script)
return true
end
+local function script_description(script)
+ return script.filename and ("from file: " .. script.filename)
+ or ("with id: " .. script.id)
+end
+
local function load_script_task(script, task, is_write)
local rspamd_redis = require "rspamd_redis"
local opts = prepare_redis_call(script)
@@ -1230,7 +1235,8 @@ local function load_script_task(script, task, is_write)
opt.callback = function(err, data)
if err then
if string.match(err, 'ERR') then
- logger.errx(task, 'cannot upload script to %s: %s; registered from: %s:%s',
+ logger.errx(task, 'cannot upload script %s to %s: %s; registered from: %s:%s',
+ script_description(script),
opt.upstream:get_addr():to_string(true),
err, script.caller.short_src, script.caller.currentline)
opt.upstream:fail()
@@ -1238,7 +1244,8 @@ local function load_script_task(script, task, is_write)
return
else
-- Assume temporary error
- logger.infox(task, 'temporary error uploading script to %s: %s; registered from: %s:%s',
+ logger.infox(task, 'temporary error uploading script %s to %s: %s; registered from: %s:%s',
+ script_description(script),
opt.upstream:get_addr():to_string(true),
err, script.caller.short_src, script.caller.currentline)
script.servers_ready[idx] = "tempfail"
@@ -1247,10 +1254,11 @@ local function load_script_task(script, task, is_write)
else
opt.upstream:ok()
logger.infox(task,
- "uploaded redis script to %s %s %s, sha: %s",
+ "uploaded redis script to %s %s, sha: %s",
opt.upstream:get_addr():to_string(true),
- script.filename and "from file" or "with id", script.filename or script.id, data)
+ script_description(script), data)
script.sha = data -- We assume that sha is the same on all servers
+ script.servers_ready[idx] = "done"
end
if is_all_servers_ready(script) then
script_set_loaded(script)
@@ -1289,7 +1297,8 @@ local function load_script_taskless(script, cfg, ev_base, is_write)
opt.callback = function(err, data)
if err then
if string.match(err, 'ERR') then
- logger.errx(cfg, 'cannot upload script to %s: %s; registered from: %s:%s',
+ logger.errx(cfg, 'cannot upload script %s to %s: %s; registered from: %s:%s',
+ script_description(script),
opt.upstream:get_addr():to_string(true),
err, script.caller.short_src, script.caller.currentline)
opt.upstream:fail()
@@ -1297,7 +1306,8 @@ local function load_script_taskless(script, cfg, ev_base, is_write)
return
else
-- Assume temporary error
- logger.infox(cfg, 'temporary error uploading script to %s: %s; registered from: %s:%s',
+ logger.infox(cfg, 'temporary error uploading script %s to %s: %s; registered from: %s:%s',
+ script_description(script),
opt.upstream:get_addr():to_string(true),
err, script.caller.short_src, script.caller.currentline)
script.servers_ready[idx] = "tempfail"
@@ -1306,11 +1316,13 @@ local function load_script_taskless(script, cfg, ev_base, is_write)
else
opt.upstream:ok()
logger.infox(cfg,
- "uploaded redis script to %s %s %s, sha: %s",
+ "uploaded redis script %s to %s %s %s, sha: %s",
+ script_description(script),
opt.upstream:get_addr():to_string(true),
script.filename and "from file" or "with id", script.filename or script.id,
data)
script.sha = data -- We assume that sha is the same on all servers
+ script.servers_ready[idx] = "done"
end
if is_all_servers_ready(script) then
@@ -1322,7 +1334,8 @@ local function load_script_taskless(script, cfg, ev_base, is_write)
local ret = rspamd_redis.make_request(opt)
if not ret then
- logger.errx('cannot execute redis request to load script on %s',
+ logger.errx('cannot execute redis request to load script %s on %s',
+ script_description(script),
opt.upstream:get_addr())
script.servers_ready[idx] = "failed"
opt.upstream:fail()
@@ -1332,7 +1345,7 @@ local function load_script_taskless(script, cfg, ev_base, is_write)
if is_all_servers_ready(script) then
script_set_loaded(script)
elseif is_all_servers_failed(script) then
- script.fatal_error = "cannot upload script to any server"
+ script.fatal_error = "cannot upload script " .. script_description(script) .. " to any server"
end
end
end
@@ -1448,10 +1461,12 @@ local function exec_redis_script(id, params, callback, keys, args)
callback(err, data)
elseif string.match(err, 'NOSCRIPT') then
-- Schedule restart
+ logger.infox(params.task, 'redis script %s is not loaded (NOSCRIPT returned), scheduling reload',
+ script_description(script))
script.sha = nil
if can_reload then
table.insert(script.waitq, do_call)
- if script.in_flight == 0 then
+ if not script.servers_ready then
-- Reload scripts if this has not been initiated yet
if params.task then
load_script_task(script, params.task)
@@ -1499,6 +1514,7 @@ local function exec_redis_script(id, params, callback, keys, args)
do_call(true)
else
-- Delayed until scripts are loaded
+ logger.infox(params.task, 'redis script %s is not loaded, trying to load', script_description(script))
if not params.task then
table.insert(script.waitq, do_call)
else