spring cloud gateway中redis一直打印重连日志问题及解决
作者:Happywzy~
问题
spring cloud gateway集成了redis后,一直出现重连的日志
如下:
gateway | 2020-06-28 10:56:11.133 INFO 1 --- [xecutorLoop-2-2] i.l.core.protocol.ConnectionWatchdog : Reconnecting, last destination was 192.171.0.9/192.171.0.9:6379
gateway | 2020-06-28 10:56:11.148 INFO 1 --- [llEventLoop-4-6] i.l.core.protocol.ReconnectionHandler : Reconnected to 192.171.0.9:6379
gateway | 2020-06-28 11:01:12.431 INFO 1 --- [xecutorLoop-2-3] i.l.core.protocol.ConnectionWatchdog : Reconnecting, last destination was 192.171.0.9/192.171.0.9:6379
gateway | 2020-06-28 11:01:12.441 INFO 1 --- [llEventLoop-4-8] i.l.core.protocol.ReconnectionHandler : Reconnected to 192.171.0.9:6379
gateway | 2020-06-28 11:06:13.231 INFO 1 --- [xecutorLoop-2-4] i.l.core.protocol.ConnectionWatchdog : Reconnecting, last destination was 192.171.0.9/192.171.0.9:6379
gateway | 2020-06-28 11:06:13.237 INFO 1 --- [llEventLoop-4-2] i.l.core.protocol.ReconnectionHandler : Reconnected to 192.171.0.9:6379
分析
spring boot 2.0之后spring-boot-starter-data-redis默认不再使用jedis连接redis,而是lettuce.
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <!-- 排除lettuce包,使用jedis代替--> <!--<exclusions>--> <!--<exclusion>--> <!--<groupId>io.lettuce</groupId>--> <!--<artifactId>lettuce-core</artifactId>--> <!--</exclusion>--> <!--</exclusions>--> </dependency> <!-- jedis --> <!--<dependency>--> <!--<groupId>redis.clients</groupId>--> <!--<artifactId>jedis</artifactId>--> <!--<version>2.9.0</version>--> <!--</dependency>-->
考虑是不是程序长时间没有使用redis,而导致连接断开.
修改连接池最小空闲连接数:
spring.redis.host=localhost spring.redis.password= # 连接超时时间(毫秒) spring.redis.timeout=10000 # Redis默认情况下有16个分片,这里配置具体使用的分片,默认是0 spring.redis.database=0 # 连接池最大连接数(使用负值表示没有限制) 默认 8 spring.redis.lettuce.pool.max-active=8 # 连接池最大阻塞等待时间(使用负值表示没有限制) 默认 -1 spring.redis.lettuce.pool.max-wait=-1 # 连接池中的最大空闲连接 默认 8 spring.redis.lettuce.pool.max-idle=8 # 连接池中的最小空闲连接 默认 0, 修改为1 spring.redis.lettuce.pool.min-idle=1
注意修改完之后需要增加新的依赖包,不然会报错
<!--配置lettuce.pool.min-idle需要增加的依赖--> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-pool2</artifactId> <version>2.4.2</version> </dependency>
重启完程序之后,发现每5分钟打印重连日志依然存在.
解决
这个不是错误,只是一个INFO级别的日志,可以日志级别调高
例如:
<logger name="io.lettuce.core.protocol" level="ERROR"> <appender-ref ref="ERROR_FILE" /> </logger>
原因
这是lettuce-core的实现里,lettuce与redis保持长连接,但是redis.conf默认配置timeout 300是当客户端闲置300秒后关闭连接(这里可以设置为0永不关闭),所以Lettuce在redis主动断开连接后会再次与redis建立连接。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。