redis 间断性耗时长问题解决

  我发现开发项目用的redis 隔一两分钟就出现 耗时问题,长达五秒。一开始以为是 redis 服务器不稳定,但运维测试发现redis稳定的,在高并发下最大耗时也就只有100毫秒左右,怎么也不可能达到5秒。

排除redis服务器稳定性问题后,就只有可能网络抖动问题 和 客户端redis配置及代码问题了,监控了 redis 耗时后发现了诡异的地方,如下图~

 

发现 耗时长的请求都是在前一个请求过来一段时间之后,我再看配置如下

发现没有配置 minIdle 这个参数,而这个参数是指定redis连接池的最小空闲连接,而jedis默认的空闲连接数是0,这就导致了隔段时间空闲连接就被全部回收了

所以加上 minIdle 这个参数就可以了。

    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxIdle" value="${redis.pool.maxIdle}" />
        <property name="minIdle" value="${redis.pool.minIdle}" />
        <property name="timeBetweenEvictionRunsMillis" value="${redis.pool.timeBetweenEvictionRunsMillis}" />
        <property name="minEvictableIdleTimeMillis" value="${redis.pool.minEvictableIdleTimeMillis}" />
        <property name="testOnBorrow" value="${redis.pool.testOnBorrow}" />
        <property name="maxTotal" value="${redis.pool.maxTotal}" />
    </bean>
#redis配置
redis.host=${REDIS_HOST}
redis.port=${REDIS_PORT}
redis.db=${REDIS_DB}
#最大能够保持idel状态的对象数
redis.pool.maxIdle=300
#redis最小空闲连接数
redis.pool.minIdle=5
#最大连接数量
redis.pool.maxTotal=301
#多长时间检查一次连接池中空闲的连接 ms
redis.pool.timeBetweenEvictionRunsMillis=30000
#空闲连接多长时间后会被收回 (ms)
redis.pool.minEvictableIdleTimeMillis=30000
#当调用borrow Object方法时,是否进行有效性检查
redis.pool.testOnBorrow=true
########reids编码格式
redis.encode=utf-8
####是否开启Redis服务应用
redis.unlock=false
#超时
redis.timeout=5000

 

参考资料:

1、http://my.oschina.net/ifeixiang/blog/365649

2、http://blog.chinaunix.net/uid-20761674-id-3527896.html

3、http://www.tuicool.com/articles/eQRvui

4、http://lib.csdn.net/article/redis/20658

转载于:https://www.cnblogs.com/xunux/p/5717122.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值