aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDmitriy Alekseev <1865999+dragoangel@users.noreply.github.com>2024-10-15 21:31:02 +0200
committerDmitriy Alekseev <1865999+dragoangel@users.noreply.github.com>2024-10-15 21:31:02 +0200
commit5f26066f137bc7130b205dba51effa43b42dc0d9 (patch)
tree68e9b9c0e5c26ced3e7ec099a01ddadac59be023 /src
parent5801ed57347add5b296babd2dfeab7251fccb373 (diff)
downloadrspamd-5f26066f137bc7130b205dba51effa43b42dc0d9.tar.gz
rspamd-5f26066f137bc7130b205dba51effa43b42dc0d9.zip
do not retry on errors in body as it will create duplicated logs
Diffstat (limited to 'src')
-rw-r--r--src/plugins/lua/elastic.lua30
1 files changed, 6 insertions, 24 deletions
diff --git a/src/plugins/lua/elastic.lua b/src/plugins/lua/elastic.lua
index f35de152b..9e3288304 100644
--- a/src/plugins/lua/elastic.lua
+++ b/src/plugins/lua/elastic.lua
@@ -116,7 +116,7 @@ local settings = {
shrink = false,
shards_count = 1,
max_gb_per_shard = 0, -- zero - disabled by default, if enabled - shards_count is ignored
- force_merge = true,
+ force_merge = false,
segments_count = 1,
},
cold = {
@@ -369,7 +369,6 @@ local function elastic_send_data(flush_all, task, cfg, ev_base)
local function http_callback(err, code, body, _)
local push_done = false
- local push_errors = false
if err then
rspamd_logger.errx(log_object, 'cannot send logs to elastic (%s): %s; failed attempts: %s/%s',
push_url, err, buffer['errors'], settings['limits']['max_fail'])
@@ -378,23 +377,10 @@ local function elastic_send_data(flush_all, task, cfg, ev_base)
local res, ucl_err = parser:parse_string(body)
if not ucl_err and res then
local obj = parser:get_object()
- if not obj['errors'] then
- push_done = true
- rspamd_logger.debugm(N, log_object, 'successfully sent payload with %s logs', nlogs_to_send)
- else
- push_errors = true
- for _, value in pairs(obj['items']) do
- if value['index']['status'] >= 400 then
- if value['index']['error'] then
- if value['index']['error']['type'] and value['index']['error']['reason'] then
- rspamd_logger.errx(log_object,
- 'cannot send logs to elastic (%s) due to error: %s status, %s type, due to: %s; failed attempts: %s/%s',
- push_url, value['index']['status'], value['index']['error']['type'], value['index']['error']['reason'],
- buffer['errors'], settings['limits']['max_fail'])
- end
- end
- end
- end
+ push_done = true
+ rspamd_logger.debugm(N, log_object, 'successfully sent payload with %s logs', nlogs_to_send)
+ if obj['errors'] then
+ rspamd_logger.debugm(N, log_object, 'faced errors while pushing logs to elastic (%s): %s', obj['errors'])
end
else
rspamd_logger.errx(log_object,
@@ -412,6 +398,7 @@ local function elastic_send_data(flush_all, task, cfg, ev_base)
buffer['errors'] = 0
upstream:ok()
else
+ upstream:fail()
if buffer['errors'] >= settings['limits']['max_fail'] then
rspamd_logger.errx(log_object, 'failed to send %s log lines, failed attempts: %s/%s, removing failed logs from bugger',
nlogs_to_send, buffer['errors'], settings['limits']['max_fail'])
@@ -420,11 +407,6 @@ local function elastic_send_data(flush_all, task, cfg, ev_base)
else
buffer['errors'] = buffer['errors'] + 1
end
- if push_errors then
- upstream:ok() -- we not assume upstream is failed if it return errors in response body
- else
- upstream:fail()
- end
end
end