为了账号安全,请及时绑定邮箱和手机立即绑定

redis资源释放问题

redis资源释放问题

BIG阳 2018-07-26 17:17:50
代码中需要用到redis,但是总会由于各种异常导致redis资源无法释放,导致获取不到资源。代码逻辑如下,求大神优化:{声明redis;获取redis;执行sql逻辑代码1;执行逻辑代码2;释放redis;}结果异常往往出现在执行sql查询,导致redis不能释放,所以改进版(1)如下:声明redis;try{获取redis;执行sql逻辑代码1;执行逻辑代码2;}catch(){}finally{释放redis;}但是这样,发现把所有的业务逻辑都包在了try-catch中,求大神帮忙改进怎样释放redi最好改进方法(2)如下:{声明redis;redis包装类进行查询删除操作1(在redis包装类每次操作后进行try-catch-finally释放);执行sql逻辑代码1;redis包装类进行查询删除操作2(在redis包装类每次操作后进行try-catch-finally释放);执行逻辑代码2;}
查看完整描述

2 回答

?
呼如林

TA贡献1798条经验 获得超3个赞

建议:
1.可以考虑用 连接池 ,减少频繁连接和释放。
2.采用 长连接,复用同一个连接。

查看完整回答
反对 回复 2018-07-30
?
弑天下

TA贡献1818条经验 获得超7个赞

个人觉得你的问题不在于连接不释放,而在于连接持有时间过长,在处理SQL期间,连接持有是没有意义的,所以可以改为:

1. 持有Redis连接,执行前置逻辑(如果有的话),释放连接2. 执行SQL逻辑(可能耗时较久)3. 再次持有连接,执行后置逻辑(如果有的话),释放连接

在有连接池的条件下,连接的开销会很小,所以不必要长时间占用连接


查看完整回答
反对 回复 2018-07-30
  • 2 回答
  • 0 关注
  • 1828 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信