解决Redis问题:JedisConnectionException: Could not get a resource from the pool
1、问题描述:
redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool
2、简要分析:
redis.clients.util.Pool.getResource
会从JedisPool实例池中返回一个可用的redis连接。分析源码可知JedisPool 继承了 redis.clients.util.Pool
,而这个Pool是通过commons-pool
开源工具包中的org.apache.commons.pool2.impl.GenericObjectPool
来实现对Jedis实例的管理的。所以我们分析一下GenericObjectPool或许能找到答案。
其中GenericObjectPool三个重要个几个属性是:
MaxActive: 最大连接数
MaxIdle: 最大空闲数
MaxWait: 最大等待时间,单位毫秒(million seconds)
连接池中无可用连接时会会进行等待maxWait时间,若超出泽抛Could not get a resource from the pool
异常。所以应根据程序实际情况合理设置这三个参数的值,尽量避免这个异常。
分析结果:
如果连接池没有可用Jedis连接,会等待maxWaitMillis(毫秒),依然没有获取到可用Jedis连接,会抛出这个异常:redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool
3、发生异常可能的情况
异常原因一、客户端没有从连接池(最大maxTotal个)拿到可用Jedis连接造成的【简称连接泄露 (常见)】
分析图如下:
JedisPool默认的maxTotal=8
,下面的代码从JedisPool中借了8次Jedis,但是没有归还,当第9次(jedisPool.getResource().ping())
GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig();
JedisPool jedisPool = new JedisPool(poolConfig, "127.0.0.1", 6379);
//向JedisPool借用8次连接,但是没有执行归还操作。
for (int i = 0; i < 8; i++) {Jedis jedis = null;try {jedis = jedisPool.getResource();jedis.ping();} catch (Exception e) {logger.error(e.getMessage(), e);}
}
jedisPool.getResource().ping();
所以推荐使用的代码规范是:
执行命令如下:
Jedis jedis = null;
try {jedis = jedisPool.getResource();//具体的命令jedis.executeCommand()
} catch (Exception e) {//如果命令有key最好把key也在错误日志打印出来,对于集群版来说通过key可以帮助定位到具体节点。logger.error(e.getMessage(), e);
} finally {//注意这里不是关闭连接,在JedisPool模式下,Jedis会被归还给资源池。if (jedis != null) jedis.close();
}
异常原因二: 业务并发量大,maxTotal确实设置小了!
举个例子:
一次命令时间(borrow|return resource + Jedis执行命令(含网络) )
的平均耗时约为1ms,一个连接的QPS大约是1000,业务期望的QPS是50000,那么理论上需要的资源池大小是50000 / 1000 = 50个,实际maxTotal可以根据理论值合理进行微调。
异常原因三: Jedis连接还的太慢
例如Redis发生了阻塞(例如慢查询等原因),所有连接在超时时间范围内等待,并发量较大时,会造成连接池资源不足。
异常原因四: 其他问题
例如丢包、DNS、客户端TCP参数配置,具体可以参考:Jedis介绍及常见问题分析
异常原因五: 检查Redis的配置是否正确,IP端口【值得反思】
4、解决方案:
1、检查Redis的配置是否正确,IP端口【值得反思】
2、调整配置参数。但是,不要被异常的表象所迷惑,简单地认为连接池不够就盲目加大maxTotal,要具体问题具体分析。连接池参数优化可以参考:JedisPool资源池优化
3、客户端没有从连接池(最大maxTotal个)拿到可用Jedis连接造成的,简称连接泄露 (常见),所以推荐使用的代码规范是如下:
执行命令如下:
Jedis jedis = null;
try {jedis = jedisPool.getResource();//具体的命令jedis.executeCommand()
} catch (Exception e) {//如果命令有key最好把key也在错误日志打印出来,对于集群版来说通过key可以帮助定位到具体节点。logger.error(e.getMessage(), e);
} finally {//注意这里不是关闭连接,在JedisPool模式下,Jedis会被归还给资源池。if (jedis != null) jedis.close();
}
参考:Jedis常见异常汇总
ok,end…
简单点,写博客的方式简单点。
解决Redis问题:JedisConnectionException: Could not get a resource from the pool相关推荐
- JedisConnectionException: Could not get a resource from the pool
最近,使用Redis做缓存时,老是提示JedisConnectionException: Could not get a resource from the pool,Jedis无法从池中获取资源,稍 ...
- redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool
解决办法:调整JedisPoolConfig中maxActive为适合自己系统的阀值. <bean id="dataJedisPoolConfig" class=" ...
- springboot项目报错JedisConnectionException: Could not get a resource from the pool
读取redis配置文件错误,更改下面配置后启动正常
- 使用客户端jedis时报错Could not get a resource from the pool 以及使用Spring Data Redis报错解决方法
一.Jedis 报错 今天在使用jedis时,一直报错 Could not get a resource from the pool 在网上找了好多解决的方法,并且找了半天错误,才发现是我的启动方式有 ...
- 解决redis远程连接超时:Connection timed out
今天在项目中连接远程redis时,抛出连接超时异常:connect timed out. 详细信息例如以下: org.springframework.data.redis.connection.Poo ...
- redis报错,Could not get a resource from the pool,Unable to validate object找不到可用的连接池
报错如下: 追踪源码发现第一个错误信息redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource ...
- redis中 Could not get a resource from the pool 异常解决
描述 这个错误产生的前提是这样的,将数据存入redis(新安装的)中,在通过连接池获取jedis实例时,产生如下错误( Could not get a resource from the pool). ...
- 解决Redis报错:MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist
解决Redis报错:MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on ...
- 集群空间服务器接收不到消息,解决Redis集群条件下键空间通知服务器接收不到消息的问题...
解决Redis集群条件下键空间通知服务器接收不到消息的问题 键空间通知介绍 键空间通知使得客户端可以通过订阅频道或模式, 来接收那些以某种方式改动了 Redis 数据集的事件. 可以通过对redis的 ...
最新文章
- Python-生成模拟原始脑电数据
- python个人项目-个人项目 python实现
- 七周三次课(1月24日) 10.11 Linux网络相关 10.12 firewalld和netfilter 10.13 netfilter5表5链介绍 10.14 iptables语法...
- python关闭线程根据id_python之线程相关操作
- 《全民捕鱼》游戏分析
- 容易的linux自动化运维工具之clinet端(二)
- python简单爬虫课题_VS2019python爬虫入门
- mysql 8.0.12解压版安装教程_mysql 8.0.12 解压版安装教程
- leetcode113. 路径总和 II
- 美团深度学习系统的工程实践
- 阿里云与A站在一起后,悄悄干了件大事
- U-boot.lds文件分析
- 新鲜出炉--Struct2、Hibernate3、Spring3框架搭建实战
- (2)通过输入参数(测量数据)构建三维体模型(01)
- 关于动态规划,你该了解这些!
- 浏览器linux2019,2019火狐浏览器
- camera - YUV422
- 战舰世界换服务器改什么文件,战舰世界国服更新账号继承并合区,直营服已更新092...
- 二补数 (2's complement)
- mysql engine ndb_ndbcluster引擎表同步到innodb引擎报错Error 'Unknown storage engine 'ndbcluster'...
热门文章
- 【APICloud系列|1】华为应用市场 应用版权证书或代理证书怎么填
- ios系统光遇是什么服务器,光遇什么时候合服?光遇国服安卓和IOS什么时候互通?...
- Tracup|远程办公,为什么会让管理者抓狂?
- 加速更新DNS解析记录的方法
- 大数据解读《旅行青蛙》崛起之谜
- 温莎计算机应用硕士是针对国际学生的吗,专业推荐 | 加拿大留学,温莎大学英语计算机专业了解一下...
- 【点云系列】综述: Deep Learning for 3D Point Clouds: A Survey
- 朗月孤舟一尺半,天堂地狱八十年。
- mac 下 python 批量删除 PDF 中的某些页面
- 代沐研:渡尽劫波非农在,空头有望脱苦海