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, 导致异常
    同步白名单后, 异常解除

总结

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容