diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-05-07 13:13:27 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-05-07 13:13:27 +0100 |
commit | 48d98e692130032fc2ec89b174c27820a1d5f9ac (patch) | |
tree | 4eeff24952d846e8c74315870c5c7978d98348fd | |
parent | 27a027add8439eeaf5460935fa1fe6ef7a6d5a2f (diff) | |
download | rspamd-48d98e692130032fc2ec89b174c27820a1d5f9ac.tar.gz rspamd-48d98e692130032fc2ec89b174c27820a1d5f9ac.zip |
[Feature] Better deal with backend errors
-rw-r--r-- | src/rspamd_proxy.c | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/src/rspamd_proxy.c b/src/rspamd_proxy.c index dc926066c..0ddcf1014 100644 --- a/src/rspamd_proxy.c +++ b/src/rspamd_proxy.c @@ -120,6 +120,7 @@ struct rspamd_proxy_backend_connection { struct upstream *up; struct rspamd_http_connection *backend_conn; ucl_object_t *results; + const gchar *err; struct rspamd_proxy_session *s; gint backend_sock; enum rspamd_backend_flags flags; @@ -661,7 +662,7 @@ proxy_call_cmp_script (struct rspamd_proxy_session *session, gint cbref) } else { lua_pushstring (L, conn->name); - lua_pushstring (L, "no results"); + lua_pushstring (L, conn->err ? conn->err : "unknown error"); lua_settable (L, -3); } } @@ -815,9 +816,15 @@ proxy_backend_mirror_error_handler (struct rspamd_http_connection *conn, GError struct rspamd_proxy_session *session; session = bk_conn->s; - msg_info_session ("abnormally closing connection from backend: %s, error: %s", - rspamd_inet_address_to_string (rspamd_upstream_addr (bk_conn->up)), - err->message); + msg_info_session ("abnormally closing connection from backend: %s:%s, " + "error: %e", + bk_conn->name, + rspamd_inet_address_to_string (rspamd_upstream_addr (bk_conn->up)), + err); + + if (err) { + bk_conn->err = rspamd_mempool_strdup (session->pool, err->message); + } proxy_backend_close_connection (bk_conn); REF_RELEASE (bk_conn->s); @@ -834,10 +841,14 @@ proxy_backend_mirror_finish_handler (struct rspamd_http_connection *conn, if (!proxy_backend_parse_results (session, bk_conn, session->ctx->lua_state, -1, msg->body_buf.begin, msg->body_buf.len)) { - msg_warn_session ("cannot parse results from the mirror backend %s", - bk_conn->name); + msg_warn_session ("cannot parse results from the mirror backend %s:%s", + bk_conn->name, + rspamd_inet_address_to_string (rspamd_upstream_addr (bk_conn->up))); + bk_conn->err = "cannot parse ucl"; } + msg_info_session ("finished mirror connection to %s", bk_conn->name); + proxy_backend_close_connection (bk_conn); REF_RELEASE (bk_conn->s); @@ -1057,6 +1068,7 @@ proxy_client_finish_handler (struct rspamd_http_connection *conn, } } else { + msg_info_session ("finished master connection"); proxy_backend_close_connection (session->master_conn); REF_RELEASE (session); } |