开发者社区> 问答> 正文

redis资源释放问题

代码中需要用到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;
}

展开
收起
李博 bluemind 2019-04-08 16:57:04 2456 0
1 条回答
写回答
取消 提交回答
  • 云栖社区Java、Redis、MongoDB运营小编,有意合作请联系钉钉:15810436147

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

    1. 持有Redis连接,执行前置逻辑(如果有的话),释放连接
    2. 执行SQL逻辑(可能耗时较久)
    3. 再次持有连接,执行后置逻辑(如果有的话),释放连接
      在有连接池的条件下,连接的开销会很小,所以不必要长时间占用连接
    2019-07-17 23:32:50
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
ApsaraDB for Redis——与创客同行 立即下载
微博的Redis定制之路 立即下载
云数据库Redis版的开源之路 立即下载