Jedis Could not get a resource from the pool

一、错误描述

使用Jedis连接池模式的时候容易出现的错误是无法获取连接池

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

对于这类问题的原因有几类,可以根据以下一一进行排查

二、逐一排查

2.1 网络检查

首先检查是否网络问题,可以通过telnet host 6379进行简单测试,连上之后auth 密码回车查看是否返回+OKrn,如果能够正确返回继续检查ping请求或者读写请求是否正常返回,操作多次排查网络问题影响。

2.2 JedisPool连接数设置检查

JedisPool使用的时候需要进行连接池的设置,用户在超过MaxTotal连接数的时候也会出现获取不到连接池的情况,这个时候可以在访问客户端上通过netstat -an | grep 6379 | grep EST | wc -l
查看链接的客户端链接数目,并且比较这个数目和JedisPool配置的MaxTotal的值,如果没有明显超过或者接近就可以排除JedisPool连接池配置的影响。

2.3 JedisPool连接池代码检查

对于JedisPool连接池的操作,每次getResource之后需要调用returnResource````或者close```进行归还,可以查看代码是否有正确使用,代码sample可以参考上面的

2.4 检查是否发生nf_conntrack丢包

通过dmesg检查客户端是否有异常

nf_conntrack: table full, dropping packet

如果发生nf_conntract丢包可以通过修改设置sysctl -w net.netfilter.nf_conntrack_max=120000

2.5 检查是否TIME_WAIT问题

通过ss -s查看time wait链接是否过多

如果TIME_WAIT过多可以修改以下参数

sysctl -w net.ipv4.tcp_max_tw_buckets=180000
sysctl -w net.ipv4.tcp_tw_recycle=1

2.6 检查是否DNS问题

通过在/etc/hosts文件直接绑定host地址,绑定完成之后查看问题是否还存在,如果还存在则不是DNS解析问题

192.168.1.1  *.redis.xxx.com

三、总结

如果按照上面排查之后还有问题可以通过抓包并将报错时间点,报错信息,然后进行分析。抓包命令为

sudo tcpdump -i eth0 tcp and port 6379 -n -nn -s 74 -w redis.cap

转自:
https://yq.aliyun.com/articles/73894?spm=5176.8091938.0.0.iOI0kR

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用Jedis连接池时,有时会遇到"Could not get a resource from the pool"的异常。这个异常通常是由于连接池中的连接资源被耗尽或者连接池未正确初始化导致的。以下是一些可能的原因和解决方法: 1. 连接池资源耗尽:这可能是因为连接池中的连接资源已经全部被占用,没有可用的连接资源了。解决方法是增加连接池的最大连接数或者增加连接池的最大等待时间。 2. 连接池未正确初始化:这可能是因为连接池未正确初始化导致的。解决方法是检查连接池的配置是否正确,包括连接池的最大连接数、最大等待时间等。 3. 连接池连接超时:这可能是因为连接池中的连接在一定时间内没有被释放,导致连接超时。解决方法是检查连接池的连接超时时间设置,可以适当调整连接超时时间。 4. 网络问题:这可能是因为网络问题导致连接池无法获取连接资源。解决方法是检查网络连接是否正常,可以尝试重新连接或者重启连接池。 下面是一个示例代码,演示了如何使用Jedis连接池来避免"Could not get a resource from the pool"异常: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; public class JedisPoolExample { public static void main(String[] args) { // 创建连接池配置对象 JedisPoolConfig poolConfig = new JedisPoolConfig(); poolConfig.setMaxTotal(10); // 设置最大连接数 poolConfig.setMaxWaitMillis(1000); // 设置最大等待时间 // 创建连接池对象 JedisPool jedisPool = new JedisPool(poolConfig, "localhost", 6379); // 从连接池中获取连接 try (Jedis jedis = jedisPool.getResource()) { // 使用连接进行操作 jedis.set("key", "value"); String value = jedis.get("key"); System.out.println(value); } catch (Exception e) { e.printStackTrace(); } finally { // 关闭连接池 jedisPool.close(); } } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值