当前位置: 首页 > news >正文

湛江网站设计公司怎么制作干花

湛江网站设计公司,怎么制作干花,html搜索框代码,东四做网站1、问题描述: redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool 2、简要分析: redis.clients.util.Pool.getResource会从JedisPool实例池中返回一个可用的redis连接。分析源码可知JedisPool 继承了 r…

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常见异常汇总 | 程序猿DD

http://www.yayakq.cn/news/97647/

相关文章:

  • 淘宝联盟的网站怎么做做文献综述的文章用什么网站
  • 广广东网站建设上海网站定制设计
  • 学做网站有没有前途怎样建立一个网站步骤
  • 网站建设职业情况建e室内设计网址
  • 汕头企业建站系统第三方小程序开发平台有哪些
  • 天通苑网站建设免费网站建站手机
  • 怎么自己写代码做网站外贸网站 英文
  • 广东智能网站建设哪家有wordpress 后台菜单修改
  • 盘锦威旺做网站建设建设银行官方网站电子银行登录
  • 做网站编辑需要看什么书织梦做的网站在百度搜索页劫取
  • 高端it网站建设软件开发做网站
  • 网站模板下载后如何使用strange wordpress主题
  • 小型企业网站建设报告模拟组建过程wordpress是否免费
  • asp.net网站开发介绍电商培训机构排名前十
  • 汕头市广州新业建设有限公司网站寻找做网站的合作伙伴北京
  • 网站由谁备案wordpress 内容采集
  • 服装厂网站模板江苏宜兴做网站的电话
  • 高校网站建设管理制度网站项目建设背景
  • 赛门仕博做网站怎么样物流官网网站
  • 电子科技产品网站建设百度权重划分等级
  • 我帮你建站做外贸网站一般多少钱
  • 阿里云建设网站做网站在哪个地方买空间
  • 如何用word做网站u钙网logo设计影视剪辑
  • 长沙网站建设zh68模板网站建设珠海
  • 预约做家庭清洁的网站wordpress 生成
  • 房子如何上网站做民宿订阅号可以做网站链接吗
  • 怎样设置个人官方网站企业网站建设三网合一
  • 在市场部做网站多少工资如何在wordpress底部添加友情链接
  • 湛江企业网站怎么建设网站建设在360属于什么类目
  • 论坛型网站开发品牌商城网站建设