JedisPool连接池

网友投稿 674 2022-11-24

JedisPool连接池

JedisPool连接池

查看 Redis 连接数

172.31.2.111:7002> CONFIG GET maxclients1) "maxclients"2) "10000"172.31.2.1111:7002>

172.31.1.135:7002> CONFIG GET maxclients                                            pom.xml 依赖

redis.clients jedis 2.9.0 compile

xml配置

参数说明

资源设置和使用

序号

参数名

含义

默认值

使用建议

1

maxTotal

资源池中最大连接数

8

设置建议见下节

2

maxIdle

资源池允许最大空闲的连接数

8

设置建议见下节

3

minIdle

资源池确保最少空闲的连接数

0

设置建议见下节

4

blockWhenExhausted

当资源池用尽后,调用者是否要等待。只有当为true时,下面的maxWaitMillis才会生效

true

建议使用默认值

5

maxWaitMillis

当资源池连接用尽后,调用者的最大等待时间(单位为毫秒)

-1:表示永不超时

不建议使用默认值

6

testOnBorrow

向资源池借用连接时是否做连接有效性检测(ping),无效连接会被移除

false

业务量很大时候建议设置为false(多一次ping的开销)。

7

testOnReturn

向资源池归还连接时是否做连接有效性检测(ping),无效连接会被移除

false

业务量很大时候建议设置为false(多一次ping的开销)。

8

jmxEnabled

是否开启jmx监控,可用于监控

true

建议开启,但应用本身也要开启

空闲资源监测

序号

参数名

含义

默认值

使用建议

1

testWhileIdle

是否开启空闲资源监测

false

true

2

timeBetweenEvictionRunsMillis

空闲资源的检测周期(单位为毫秒)

-1:不检测

建议设置,周期自行选择,也可以默认也可以使用下面JedisPoolConfig中的配置

3

minEvictableIdleTimeMillis

资源池中资源最小空闲时间(单位为毫秒),达到此值后空闲资源将被移除

1000 60 30 = 30分钟

可根据自身业务决定,大部分默认值即可,也可以考虑使用下面JeidsPoolConfig中的配置

4

numTestsPerEvictionRun

做空闲资源检测时,每次的采样数

3

可根据自身应用连接数进行微调,如果设置为-1,就是对所有连接做空闲监测

如何配置

maxTotal 最大连接数

考虑的几个因素

业务并发量多大客户端命令的执行时间Redis 资源开销

这个值不是越大越好,连接过多,容易占用客户端和服务端资源。长时命令的阻塞,通过调节最大连接数,也无济于事。

maxIdle 实际上才是业务需要的最大连接数,maxTotal 是为了给出余量。maxIdel 不要设置过小,否则会建立新的连接, maxIdel 是为了控制空闲资源监测。

常见问题

redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool…Caused by: java.util.NoSuchElementException: Timeout waiting for idle objectat org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:449)

现象是无法从资源池获取到资源,原因是超时。

redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool…Caused by: java.util.NoSuchElementException: Pool exhaustedat org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:464)

现象同样是无法获得资源,但是hi因为 blockWhenExhausted为 false ,资源用尽之后,调用者不等待。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:软件设计思想:池化技术
下一篇:XMind 8 安装激活
相关文章

 发表评论

暂时没有评论,来抢沙发吧~