From 0a813270bafa97cfabf42ce30ac802a1a842bff9 Mon Sep 17 00:00:00 2001 From: Vladislav Grubov Date: Mon, 1 Apr 2024 21:35:50 +0300 Subject: [PATCH] fix: slow down retries --- .rocks/config-5.1.lua | 2 +- discovery/init.lua | 19 ++++++++++++++++--- 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/.rocks/config-5.1.lua b/.rocks/config-5.1.lua index 9f388aa..f4cdeb6 100644 --- a/.rocks/config-5.1.lua +++ b/.rocks/config-5.1.lua @@ -1,5 +1,5 @@ rocks_servers = { - "https://rocks.ochaton.me/", + "https://rocks.ochaton.me.hb.vkcs.cloud/", "http://moonlibs.github.io/rocks", -- moonlibs libs "http://rocks.tarantool.org/", -- tarantool libs "http://luarocks.org/repositories/rocks", -- luarocks diff --git a/discovery/init.lua b/discovery/init.lua index e7bd4af..0671e3f 100644 --- a/discovery/init.lua +++ b/discovery/init.lua @@ -351,6 +351,13 @@ function M:rebuild() end end +local time_tolerance_mks = 100 + +local function is_deadline_exceeded(deadline, now) + now = now or fiber.time() + return (now-deadline)*1e6 > time_tolerance_mks +end + local function tail_call(self, ctx, pcall_ok, ...) local now = fiber.time() ctx.total_time = now-ctx.started_at @@ -377,10 +384,11 @@ local function tail_call(self, ctx, pcall_ok, ...) reason = tostring(err), } - if ctx.retriable then + if ctx.retriable and not is_deadline_exceeded(ctx.deadline, fiber.time()+0.001) then -- local json = require 'json' -- log.warn("retrying call(%s, %s, %s, %s)", -- ctx.method, json.encode(ctx.args), json.encode(ctx.opts), json.encode(ctx)) + fiber.sleep(0.001) return self:call(ctx.method, ctx.args, ctx.opts, ctx) end @@ -426,9 +434,14 @@ function M:call(method, args, opts, ctx) end end - if deadline < fiber.time() then + if is_deadline_exceeded(deadline) then ctx.total_time = fiber.time() - ctx.started_at ctx.execution_time = ctx.execution_time or -1 + + if ctx.last_error then + ctx.last_error:raise() + end + box.error{ reason = ("Timeout for discovery of %s exceeded"):format(method), type = 'DiscoveryError', @@ -444,7 +457,7 @@ function M:call(method, args, opts, ctx) log.verbose("No nodes available for %s. Waiting %.3fs", method, deadline - fiber.time()) self.conds[method] = self.conds[method] or fiber.cond() self.conds[method]:wait(deadline - fiber.time()) - if deadline < fiber.time() then + if is_deadline_exceeded(deadline) then ctx.total_time = fiber.time() - ctx.started_at ctx.execution_time = ctx.execution_time or -1 box.error{