Redis:Could not get a resource from the pool 异常排查

redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool

三种情况会导致这个异常

  • 没有释放redis池中的资源
  • redis pool 配置过小
  • 无法连接到redis

异常排查

  • 首先检查代码里有没有释放资源
    检查代码后, 发现每次调用redis资源都执行了jedis原生的回收资源的close方法, 所以原因不在于此
  • 查看连接池配置, 发现连接池配置较小:
MAX_ACTIVE = 512;
MAX_IDLE = 100;

API请求峰值在100qps, 每个请求会产生6个左右的redis请求, 也就是6个(可以优化为1个)redis资源. API部署在8个docker节点上, 平均每个节点80个redis资源, 性能时满足要求的.

为了验证, 增大配置

MAX_ACTIVE = 5120;
MAX_IDLE = 1000;

测试发现还是报异常, 说明不是配置资源的问题.

  • 检查docker集群是否能连接到redis
    找运维, 发现运维在做docker集群迁移时, 没有同步redis白名单, 导致docker无法访问redis, 导致异常
    同步白名单后, 异常解除

总结

对此异常不熟, 正确的排查顺序应是
连接是否异常>>>是否释放资源>>>配置是否过小

    原文作者:搅尽脑浆
    原文地址: https://www.jianshu.com/p/53c05871fd36
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞