From: Vsevolod Stakhov Date: Sun, 25 Dec 2016 23:16:01 +0000 (+0000) Subject: [Fix] Add additional check to mark redis connection inactive X-Git-Tag: 1.5.0~483 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=db20f07830d445c20825bac3f871bc57a5c5b5b3;p=thirdparty%2Frspamd.git [Fix] Add additional check to mark redis connection inactive --- diff --git a/src/libserver/redis_pool.c b/src/libserver/redis_pool.c index 1d42ad3ff9..17fa22b1e4 100644 --- a/src/libserver/redis_pool.c +++ b/src/libserver/redis_pool.c @@ -394,12 +394,19 @@ rspamd_redis_pool_release_connection (struct rspamd_redis_pool *pool, REF_RELEASE (conn); } else { - /* Just move it to the inactive queue */ - g_queue_unlink (conn->elt->active, conn->entry); - g_queue_push_head_link (conn->elt->inactive, conn->entry); - conn->active = FALSE; - rspamd_redis_pool_schedule_timeout (conn); - msg_debug_rpool ("mark connection inactive"); + /* Ensure that there are no callbacks attached to this conn */ + if (ctx->replies.head == NULL) { + /* Just move it to the inactive queue */ + g_queue_unlink (conn->elt->active, conn->entry); + g_queue_push_head_link (conn->elt->inactive, conn->entry); + conn->active = FALSE; + rspamd_redis_pool_schedule_timeout (conn); + msg_debug_rpool ("mark connection inactive"); + } + else { + msg_debug_rpool ("closed connection due to callbacks leftover"); + REF_RELEASE (conn); + } } REF_RELEASE (conn); diff --git a/src/lua/lua_redis.c b/src/lua/lua_redis.c index 3566c7e116..7c5e84735a 100644 --- a/src/lua/lua_redis.c +++ b/src/lua/lua_redis.c @@ -751,7 +751,7 @@ lua_redis_make_request (lua_State *L) sp_ud->w = NULL; } - REDIS_RETAIN (ctx); + REDIS_RETAIN (ctx); /* Cleared by fin event */ ctx->cmds_pending ++; double_to_tv (timeout, &tv); event_set (&sp_ud->timeout, -1, EV_TIMEOUT, lua_redis_timeout, sp_ud);