猿问

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;
}


BIG阳
浏览 1913回答 2
2回答

呼如林

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

弑天下

个人觉得你的问题不在于连接不释放,而在于连接持有时间过长,在处理SQL期间,连接持有是没有意义的,所以可以改为:1. 持有Redis连接,执行前置逻辑(如果有的话),释放连接2. 执行SQL逻辑(可能耗时较久)3. 再次持有连接,执行后置逻辑(如果有的话),释放连接在有连接池的条件下,连接的开销会很小,所以不必要长时间占用连接
随时随地看视频慕课网APP
我要回答