Redis之频繁出现连接数达到上线导致服务不可用

最近测试、生产环境服务频繁出现从Redis连接池获取不到连接或者连接数达到上线导致服务不能正常使用,设计上没有处理Redis异常导致Redis故障或不可用不会从数据库读取数据影响服务可用性。
从以下两方面解决该问题:
1、Redis配置优化
原先Redis配置如下,没有做连接数限制
# 连接池最大连接数(使用负值表示没有限制) 
pool.max-active: -1 
# 连接池最大阻塞等待时间(使用负值表示没有限制) 
pool.max-wait: -1

现在配置如下
# 连接超时时间(毫秒)当客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能
timeout: 根据实际设置值 
# 连接池最大连接数(使用负值表示没有限制) 
pool.max-active: 根据实际设置值 
# 连接池最大阻塞等待时间(使用负值表示没有限制) 
pool.max-wait: 根据实际设置值 
# 连接池中的最大空闲连接 
pool.max-idle: 根据实际设置值 
# 连接池中的最小空闲连接 
pool.min-idle: 0

2、程序中Redis操作异常捕获
之前程序中先Redis再数据库获取数据,对于Redis异常情况没有捕获,一旦Redis故障或异常请求直接以抛出异常结束。这部分程序需要优化即使Redis不可用最终到数据库去查询数据。

参考
Redis连接的客户端(connected_clients)数过高或者不减的问题解决方案

 

你可能感兴趣的:(Redis)