diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-06-17 13:53:56 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-06-17 13:53:56 +0100 |
commit | 9b78f62efea1d2ad4da465a592ea3dc8b3afdcfc (patch) | |
tree | 75797b7f0d79029d853559df129b6fc3fc445812 /src/rspamd_proxy.c | |
parent | 2463093c9d11f897cbc96120930b41be6cacfbf3 (diff) | |
download | rspamd-9b78f62efea1d2ad4da465a592ea3dc8b3afdcfc.tar.gz rspamd-9b78f62efea1d2ad4da465a592ea3dc8b3afdcfc.zip |
[Feature] Add different timeouts for proxy connections
Diffstat (limited to 'src/rspamd_proxy.c')
-rw-r--r-- | src/rspamd_proxy.c | 36 |
1 files changed, 29 insertions, 7 deletions
diff --git a/src/rspamd_proxy.c b/src/rspamd_proxy.c index b7e0c9618..20044cfe5 100644 --- a/src/rspamd_proxy.c +++ b/src/rspamd_proxy.c @@ -67,6 +67,8 @@ struct rspamd_http_upstream { gchar *name; struct upstream_list *u; struct rspamd_cryptobox_pubkey *key; + gdouble timeout; + struct timeval io_tv; gint parser_from_ref; gint parser_to_ref; gboolean local; @@ -78,6 +80,8 @@ struct rspamd_http_mirror { struct upstream_list *u; struct rspamd_cryptobox_pubkey *key; gdouble prob; + gdouble timeout; + struct timeval io_tv; gint parser_from_ref; gint parser_to_ref; gboolean local; @@ -130,6 +134,7 @@ struct rspamd_proxy_backend_connection { ucl_object_t *results; const gchar *err; struct rspamd_proxy_session *s; + struct timeval *io_tv; gint backend_sock; enum rspamd_backend_flags flags; gint parser_from_ref; @@ -287,6 +292,7 @@ rspamd_proxy_parse_upstream (rspamd_mempool_t *pool, up->parser_from_ref = -1; up->parser_to_ref = -1; up->name = g_strdup (ucl_object_tostring (elt)); + up->timeout = ctx->timeout; elt = ucl_object_lookup (obj, "key"); if (elt != NULL) { @@ -328,6 +334,11 @@ rspamd_proxy_parse_upstream (rspamd_mempool_t *pool, up->local = TRUE; } + elt = ucl_object_lookup (obj, "timeout"); + if (elt) { + ucl_object_todouble_safe (elt, &up->timeout); + } + /* * Accept lua function here in form * fun :: String -> UCL @@ -340,6 +351,8 @@ rspamd_proxy_parse_upstream (rspamd_mempool_t *pool, } } + double_to_tv (up->timeout, &up->io_tv); + g_hash_table_insert (ctx->upstreams, up->name, up); return TRUE; @@ -402,6 +415,7 @@ rspamd_proxy_parse_mirror (rspamd_mempool_t *pool, up->name = g_strdup (ucl_object_tostring (elt)); up->parser_to_ref = -1; up->parser_from_ref = -1; + up->timeout = ctx->timeout; elt = ucl_object_lookup (obj, "key"); if (elt != NULL) { @@ -446,6 +460,11 @@ rspamd_proxy_parse_mirror (rspamd_mempool_t *pool, up->local = TRUE; } + elt = ucl_object_lookup (obj, "timeout"); + if (elt) { + ucl_object_todouble_safe (elt, &up->timeout); + } + /* * Accept lua function here in form * fun :: String -> UCL @@ -463,6 +482,8 @@ rspamd_proxy_parse_mirror (rspamd_mempool_t *pool, up->settings_id = g_strdup (ucl_object_tostring (elt)); } + double_to_tv (up->timeout, &up->io_tv); + g_ptr_array_add (ctx->mirrors, up); return TRUE; @@ -593,7 +614,7 @@ init_rspamd_proxy (struct rspamd_config *cfg) ctx = g_malloc0 (sizeof (struct rspamd_proxy_ctx)); ctx->magic = rspamd_rspamd_proxy_magic; - ctx->timeout = 5.0; + ctx->timeout = 10.0; ctx->upstreams = g_hash_table_new (rspamd_strcase_hash, rspamd_strcase_equal); ctx->mirrors = g_ptr_array_new (); ctx->rotate_tm = DEFAULT_ROTATION_TIME; @@ -987,7 +1008,7 @@ proxy_open_mirror_connections (struct rspamd_proxy_session *session) sizeof (*bk_conn)); bk_conn->s = session; bk_conn->name = m->name; - + bk_conn->io_tv = &m->io_tv; bk_conn->up = rspamd_upstream_get (m->u, RSPAMD_UPSTREAM_ROUND_ROBIN, NULL, 0); @@ -1040,13 +1061,13 @@ proxy_open_mirror_connections (struct rspamd_proxy_session *session) rspamd_http_connection_write_message_shared (bk_conn->backend_conn, msg, NULL, NULL, bk_conn, bk_conn->backend_sock, - &session->ctx->io_tv, session->ctx->ev_base); + bk_conn->io_tv, session->ctx->ev_base); } else { rspamd_http_connection_write_message (bk_conn->backend_conn, msg, NULL, NULL, bk_conn, bk_conn->backend_sock, - &session->ctx->io_tv, session->ctx->ev_base); + bk_conn->io_tv, session->ctx->ev_base); } g_ptr_array_add (session->mirror_conns, bk_conn); @@ -1120,7 +1141,7 @@ proxy_backend_master_finish_handler (struct rspamd_http_connection *conn, rspamd_http_connection_write_message (session->client_conn, msg, NULL, NULL, session, session->client_sock, - &session->ctx->io_tv, session->ctx->ev_base); + bk_conn->io_tv, session->ctx->ev_base); return 0; } @@ -1184,6 +1205,7 @@ proxy_client_finish_handler (struct rspamd_http_connection *conn, else { session->master_conn->up = rspamd_upstream_get (backend->u, RSPAMD_UPSTREAM_ROUND_ROBIN, NULL, 0); + session->master_conn->io_tv = &backend->io_tv; if (session->master_conn->up == NULL) { msg_err_session ("cannot select upstream for %s", host ? hostbuf : "default"); @@ -1235,14 +1257,14 @@ proxy_client_finish_handler (struct rspamd_http_connection *conn, session->master_conn->backend_conn, msg, NULL, NULL, session->master_conn, session->master_conn->backend_sock, - &session->ctx->io_tv, session->ctx->ev_base); + session->master_conn->io_tv, session->ctx->ev_base); } else { rspamd_http_connection_write_message ( session->master_conn->backend_conn, msg, NULL, NULL, session->master_conn, session->master_conn->backend_sock, - &session->ctx->io_tv, session->ctx->ev_base); + session->master_conn->io_tv, session->ctx->ev_base); } } } |