diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2021-11-09 17:06:01 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-09 17:06:01 +0000 |
commit | 00e3b544777073664b7355dac1283d96c57756ca (patch) | |
tree | 84c23753c31c7eb95de65b8bbeb1d6c5d23b1827 | |
parent | 9766a457eb860b2eeb5e3e37ff86e82e89fe8c8d (diff) | |
parent | 13ed03952481ac5aabe6fae4ae5193b94202882a (diff) | |
download | rspamd-00e3b544777073664b7355dac1283d96c57756ca.tar.gz rspamd-00e3b544777073664b7355dac1283d96c57756ca.zip |
Merge pull request #3968 from cpragadeesh/avoid_duplicate_neural_rows
[Minor] Prevent duplicate rows from being inserted into neural trainiā¦
-rw-r--r-- | src/plugins/lua/neural.lua | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/src/plugins/lua/neural.lua b/src/plugins/lua/neural.lua index 57ff9cc21..5458dd007 100644 --- a/src/plugins/lua/neural.lua +++ b/src/plugins/lua/neural.lua @@ -225,7 +225,7 @@ local function ann_push_task_result(rule, task, verdict, score, set) local vec = neural_common.result_to_vector(task, set) local str = rspamd_util.zstd_compress(table.concat(vec, ';')) - local target_key = set.ann.redis_key .. '_' .. learn_type + local target_key = set.ann.redis_key .. '_' .. learn_type .. '_set' local function learn_vec_cb(_err) if _err then @@ -244,7 +244,7 @@ local function ann_push_task_result(rule, task, verdict, score, set) nil, true, -- is write learn_vec_cb, --callback - 'LPUSH', -- command + 'SADD', -- command { target_key, str } -- arguments ) else @@ -363,8 +363,8 @@ local function do_train_ann(worker, ev_base, rule, set, ann_key) nil, false, -- is write redis_ham_cb, --callback - 'LRANGE', -- command - {ann_key .. '_ham', '0', '-1'} + 'SMEMBERS', -- command + {ann_key .. '_ham_set'} ) end end @@ -381,8 +381,8 @@ local function do_train_ann(worker, ev_base, rule, set, ann_key) nil, false, -- is write redis_spam_cb, --callback - 'LRANGE', -- command - {ann_key .. '_spam', '0', '-1'} + 'SMEMBERS', -- command + {ann_key .. '_spam_set'} ) rspamd_logger.infox(rspamd_config, 'lock ANN %s:%s (key name %s) for learning', @@ -700,8 +700,8 @@ local function maybe_train_existing_ann(worker, ev_base, rule, set, profiles) nil, false, -- is write redis_len_cb_gen(initiate_train, 'ham', true), --callback - 'LLEN', -- command - {ann_key .. '_ham'} + 'SCARD', -- command + {ann_key .. '_ham_set'} ) end @@ -711,8 +711,8 @@ local function maybe_train_existing_ann(worker, ev_base, rule, set, profiles) nil, false, -- is write redis_len_cb_gen(check_ham_len, 'spam', false), --callback - 'LLEN', -- command - {ann_key .. '_spam'} + 'SCARD', -- command + {ann_key .. '_spam_set'} ) end end |