diff options
Diffstat (limited to 'src/libutil')
-rw-r--r-- | src/libutil/upstream.c | 74 | ||||
-rw-r--r-- | src/libutil/upstream.h | 2 |
2 files changed, 47 insertions, 29 deletions
diff --git a/src/libutil/upstream.c b/src/libutil/upstream.c index 83da7a3e5..69f1ed9e4 100644 --- a/src/libutil/upstream.c +++ b/src/libutil/upstream.c @@ -724,78 +724,96 @@ rspamd_upstream_set_inactive (struct upstream_list *ls, struct upstream *upstrea } void -rspamd_upstream_fail (struct upstream *up, gboolean addr_failure) +rspamd_upstream_fail (struct upstream *upstream, gboolean addr_failure) { gdouble error_rate = 0, max_error_rate = 0; gdouble sec_last, sec_cur; struct upstream_addr_elt *addr_elt; struct upstream_list_watcher *w; - if (up->ctx && up->active_idx != -1) { + if (upstream->ctx && upstream->active_idx != -1) { sec_cur = rspamd_get_ticks (FALSE); - RSPAMD_UPSTREAM_LOCK (up); - if (up->errors == 0) { + RSPAMD_UPSTREAM_LOCK (upstream); + if (upstream->errors == 0) { /* We have the first error */ - up->last_fail = sec_cur; - up->errors = 1; + upstream->last_fail = sec_cur; + upstream->errors = 1; - DL_FOREACH (up->ls->watchers, w) { + DL_FOREACH (upstream->ls->watchers, w) { if (w->events_mask & RSPAMD_UPSTREAM_WATCH_FAILURE) { - w->func (up, RSPAMD_UPSTREAM_WATCH_FAILURE, 1, w->ud); + w->func (upstream, RSPAMD_UPSTREAM_WATCH_FAILURE, 1, w->ud); } } } else { - sec_last = up->last_fail; + sec_last = upstream->last_fail; if (sec_cur >= sec_last) { - up->errors ++; + upstream->errors ++; - DL_FOREACH (up->ls->watchers, w) { + DL_FOREACH (upstream->ls->watchers, w) { if (w->events_mask & RSPAMD_UPSTREAM_WATCH_FAILURE) { - w->func (up, RSPAMD_UPSTREAM_WATCH_FAILURE, up->errors, w->ud); + w->func (upstream, RSPAMD_UPSTREAM_WATCH_FAILURE, + upstream->errors, w->ud); } } - if (sec_cur - sec_last >= up->ls->limits.error_time) { - error_rate = ((gdouble)up->errors) / (sec_cur - sec_last); - max_error_rate = ((gdouble)up->ls->limits.max_errors) / - up->ls->limits.error_time; + if (sec_cur - sec_last >= upstream->ls->limits.error_time) { + error_rate = ((gdouble)upstream->errors) / (sec_cur - sec_last); + max_error_rate = ((gdouble)upstream->ls->limits.max_errors) / + upstream->ls->limits.error_time; } if (error_rate > max_error_rate) { /* Remove upstream from the active list */ - if (up->ls->ups->len > 1) { - up->errors = 0; - rspamd_upstream_set_inactive (up->ls, up); + if (upstream->ls->ups->len > 1) { + msg_debug_upstream ("mark upstream %s inactive: %.2f " + "error rate (%d errors), " + "%.2f max error rate, " + "%.1f first error time, " + "%.1f current ts, " + "%d upstreams left", + upstream->name, error_rate, upstream->errors, + max_error_rate, sec_last, sec_cur, + upstream->ls->alive->len - 1); + rspamd_upstream_set_inactive (upstream->ls, upstream); + upstream->errors = 0; } else { + msg_debug_upstream ("cannot mark last alive upstream %s " + "inactive: %.2f " + "error rate (%d errors), " + "%.2f max error rate, " + "%.1f first error time, " + "%.1f current ts", + upstream->name, error_rate, upstream->errors, + max_error_rate, sec_last, sec_cur); /* Just re-resolve addresses */ - if (sec_cur - sec_last > up->ls->limits.revive_time) { - up->errors = 0; - rspamd_upstream_resolve_addrs (up->ls, up); + if (sec_cur - sec_last > upstream->ls->limits.revive_time) { + upstream->errors = 0; + rspamd_upstream_resolve_addrs (upstream->ls, upstream); } } } - else if (sec_cur - sec_last >= up->ls->limits.error_time) { + else if (sec_cur - sec_last >= upstream->ls->limits.error_time) { /* Forget the whole interval */ - up->last_fail = sec_cur; - up->errors = 1; + upstream->last_fail = sec_cur; + upstream->errors = 1; } } } if (addr_failure) { /* Also increase count of errors for this specific address */ - if (up->addrs.addr) { - addr_elt = g_ptr_array_index (up->addrs.addr, up->addrs.cur); + if (upstream->addrs.addr) { + addr_elt = g_ptr_array_index (upstream->addrs.addr, upstream->addrs.cur); addr_elt->errors++; } } - RSPAMD_UPSTREAM_UNLOCK (up); + RSPAMD_UPSTREAM_UNLOCK (upstream); } } diff --git a/src/libutil/upstream.h b/src/libutil/upstream.h index 5d3e00514..d0d7374cf 100644 --- a/src/libutil/upstream.h +++ b/src/libutil/upstream.h @@ -60,7 +60,7 @@ void rspamd_upstreams_library_config (struct rspamd_config *cfg, /** * Add an error to an upstream */ -void rspamd_upstream_fail (struct upstream *up, gboolean addr_failure); +void rspamd_upstream_fail (struct upstream *upstream, gboolean addr_failure); /** * Increase upstream successes count |