Redis连接遭遇关闭无功果(redis连接无法关闭)

Redis是一个开源的、高性能的NoSQL Key-Value数据库,以高可用,高性能,支持数据复制,多数据中心以及Lua脚本计算等优点而受到用户的青睐;但是在使用过程中,也不免会出现错误,比如在需要关闭Redis连接时遭遇关闭无功果,让用户不知所措。那么下面就跟大家分享一下这种情况的解决方法。

网站建设哪家好,找成都创新互联公司!专注于网页设计、网站建设、微信开发、重庆小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了方城免费建站欢迎大家使用!

检查日志是一个好办法,通常会找到出错的原因以及解决方案,以下是关闭连接遭遇无功果对应的日志输出:

>Err(System.TimeoutException:TimeoutException when trying to close the connection)

从该日志可以看出,关闭连接时有一个超时异常发生,表明了Redis无法从客户端接收关闭信号,所以无法完成关闭操作,这类情况常常是由于客户端等待时间太短所致。

为了解决此问题,首先需要在连接Redis服务的时候设置ConnectionTimeout配置,让等待的时间够长:

Options options = new Options()

.OverrideConnectionTimeout(TimeSpan.FromSeconds(60))

ConnectionMultiplexer conn = ConnectionMultiplexer.Connect(“127.0.0.1:6379”,options);

此外,调整closeTimeout参数也可以解决此问题:

options.CloseTimeout = TimeSpan.FromSeconds(60);

另外,还可以通过shutdown命令来中断Redis客户端连接:

conn.GetServer(“127.0.0.1:6379”).Shutdown(allowCommandsToComplete: false);

其实,如果出现这种情况,建议使用脚本广播的方式来异步的关闭连接,具体代码如下:

IDatabase db = conn.GetDatabase();

string luaScript = “for i = 0, KEYS[1] do local c = redis.call(‘quit’,i);print(c);end ;return ‘OK'”;

var scriptResult = db.ScriptEvaluate(luaScript, new RedisKey[] { 10 });

上述代码实现的逻辑是:为KEYS[1] (此处是10)的所有会话调用quit命令关闭连接,它返回“OK”表示操作成功。

总结:Redis连接可能会遭遇关闭无功果,此时检查日志是必要的,并通过ConnectionTimeout配置、CloseTimeout参数配置或者Shutdown命令中断连接以及Lua脚本广播的方式来解决此问题。

香港云服务器机房,创新互联(www.cdcxhl.com)专业云服务器厂商,回大陆优化带宽,安全/稳定/低延迟.创新互联助力企业出海业务,提供一站式解决方案。香港服务器-免备案低延迟-双向CN2+BGP极速互访!

新闻标题:Redis连接遭遇关闭无功果(redis连接无法关闭)
分享地址:http://www.csdahua.cn/qtweb/news32/255232.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网