有时候大意总会导致故障的出现,最近一个小小问题,我也记录一下吧
在就要公司框架自己写了个redis访问dao,然后过去一段时间后线上出现过一次redis不能获取连接的频繁报错,然后当时重启恢复但是没有细跟,然后到了昨天一个happy的周末又出现这个频繁报错信息了并且有影响到线上接口了。。。。
然后定位了下,应该我写的dao里的pipeline因为查询超时异常导致没有走到pipeline的释放操作,这样累积起来就恶性循环了,因为资源实现了autoclose接口,所以可以直接套用try-resource的写法解决。
前后对比如下,这个sync也是当时迷惑我的一个地方点进去其实就是close方法,所以没注意到pipeline是一个连接型的,后面要注意这种问题了!
public List<String> pipelineLrange(final Collection<String> keys, final long start, final long end) {
if (smartJedis == null) {
return null;
}
SmartJedisPipeline pipeline = smartJedis.pipeline()