diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-07-19 11:48:57 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-07-19 11:48:57 +0100 |
commit | e49aaf4fd3b9f116ba0dc42bc108ebbf492296ca (patch) | |
tree | 973bb51d4ed8218cac4e751f83fdb4d08cd4cd13 /src/libserver/symbols_cache.c | |
parent | 244fa725db7cc475d95b4dc3e430350e9f2ff822 (diff) | |
download | rspamd-e49aaf4fd3b9f116ba0dc42bc108ebbf492296ca.tar.gz rspamd-e49aaf4fd3b9f116ba0dc42bc108ebbf492296ca.zip |
[Feature] Reduce number of timers queries
Diffstat (limited to 'src/libserver/symbols_cache.c')
-rw-r--r-- | src/libserver/symbols_cache.c | 49 |
1 files changed, 30 insertions, 19 deletions
diff --git a/src/libserver/symbols_cache.c b/src/libserver/symbols_cache.c index 2642b607a..b4a3275d8 100644 --- a/src/libserver/symbols_cache.c +++ b/src/libserver/symbols_cache.c @@ -162,7 +162,8 @@ static gboolean rspamd_symbols_cache_check_symbol (struct rspamd_task *task, struct symbols_cache *cache, struct cache_item *item, struct cache_savepoint *checkpoint, - gdouble *total_diff); + gdouble *total_diff, + gdouble pr); static gboolean rspamd_symbols_cache_check_deps (struct rspamd_task *task, struct symbols_cache *cache, struct cache_item *item, @@ -1083,6 +1084,7 @@ rspamd_symbols_cache_watcher_cb (gpointer sessiond, gpointer ud) struct cache_savepoint *checkpoint; struct symbols_cache *cache; gint i, remain = 0; + gdouble pr = rspamd_random_double_fast (); checkpoint = task->checkpoint; cache = task->cfg->cache; @@ -1102,7 +1104,7 @@ rspamd_symbols_cache_watcher_cb (gpointer sessiond, gpointer ud) } rspamd_symbols_cache_check_symbol (task, cache, it, checkpoint, - NULL); + NULL, pr); } } } @@ -1115,7 +1117,8 @@ rspamd_symbols_cache_check_symbol (struct rspamd_task *task, struct symbols_cache *cache, struct cache_item *item, struct cache_savepoint *checkpoint, - gdouble *total_diff) + gdouble *total_diff, + gdouble pr) { guint pending_before, pending_after; double t1, t2; @@ -1154,7 +1157,10 @@ rspamd_symbols_cache_check_symbol (struct rspamd_task *task, } if (check) { - t1 = rspamd_get_ticks (); + if (pr > 0.9) { + t1 = rspamd_get_ticks (); + } + pending_before = rspamd_session_events_pending (task->s); /* Watch for events appeared */ rspamd_session_watch_start (task->s, rspamd_symbols_cache_watcher_cb, @@ -1163,19 +1169,21 @@ rspamd_symbols_cache_check_symbol (struct rspamd_task *task, msg_debug_task ("execute %s, %d", item->symbol, item->id); item->func (task, item->user_data); - t2 = rspamd_get_ticks (); - diff = (t2 - t1) * 1e6; + if (pr > 0.9) { + t2 = rspamd_get_ticks (); + diff = (t2 - t1) * 1e6; - if (total_diff) { - *total_diff += diff; - } + if (total_diff) { + *total_diff += diff; + } - if (diff > slow_diff_limit) { - msg_info_task ("slow rule: %s: %d ms", item->symbol, - (gint)(diff / 1000.)); - } + if (diff > slow_diff_limit) { + msg_info_task ("slow rule: %s: %d ms", item->symbol, + (gint)(diff / 1000.)); + } - rspamd_set_counter (item, diff); + rspamd_set_counter (item, diff); + } rspamd_session_watch_stop (task->s); pending_after = rspamd_session_events_pending (task->s); @@ -1213,6 +1221,7 @@ rspamd_symbols_cache_check_deps (struct rspamd_task *task, struct cache_dependency *dep; guint i; gboolean ret = TRUE; + gdouble pr = rspamd_random_double_fast (); if (item->deps != NULL && item->deps->len > 0) { for (i = 0; i < item->deps->len; i ++) { @@ -1246,7 +1255,8 @@ rspamd_symbols_cache_check_deps (struct rspamd_task *task, else if (!rspamd_symbols_cache_check_symbol (task, cache, dep->item, checkpoint, - NULL)) { + NULL, + pr)) { /* Now started, but has events pending */ ret = FALSE; msg_debug_task ("started check of %d symbol as dep for " @@ -1437,6 +1447,7 @@ rspamd_symbols_cache_process_symbols (struct rspamd_task * task, gboolean all_done; const gdouble max_microseconds = 3e5; guint start_events_pending; + gdouble pr = rspamd_random_double_fast (); g_assert (cache != NULL); @@ -1464,7 +1475,7 @@ rspamd_symbols_cache_process_symbols (struct rspamd_task * task, if (!isset (checkpoint->processed_bits, item->id * 2)) { rspamd_symbols_cache_check_symbol (task, cache, item, - checkpoint, &total_microseconds); + checkpoint, &total_microseconds, pr); } } checkpoint->pass = RSPAMD_CACHE_PASS_WAIT_PREFILTERS; @@ -1517,7 +1528,7 @@ rspamd_symbols_cache_process_symbols (struct rspamd_task * task, } rspamd_symbols_cache_check_symbol (task, cache, item, - checkpoint, &total_microseconds); + checkpoint, &total_microseconds, pr); } if (total_microseconds > max_microseconds) { @@ -1567,7 +1578,7 @@ rspamd_symbols_cache_process_symbols (struct rspamd_task * task, } rspamd_symbols_cache_check_symbol (task, cache, item, - checkpoint, &total_microseconds); + checkpoint, &total_microseconds, pr); } if (total_microseconds > max_microseconds) { @@ -1597,7 +1608,7 @@ rspamd_symbols_cache_process_symbols (struct rspamd_task * task, if (!isset (checkpoint->processed_bits, item->id * 2)) { rspamd_symbols_cache_check_symbol (task, cache, item, - checkpoint, &total_microseconds); + checkpoint, &total_microseconds, pr); } } checkpoint->pass = RSPAMD_CACHE_PASS_WAIT_POSTFILTERS; |