记一次系统因spring-session与Spring-redisson引起cpu波动问题

本文记录了一次系统由于引入spring-session和spring-redisson导致CPU波动的问题。通过分析发现,RedisMessageListenerContainer在监听database 0的key删除和过期事件时,当database 0存在大量key过期导致CPU波动。问题源于spring-ession的配置和线程池设置。解决方案包括设置线程池大小和正确配置database,避免类似问题发生。
摘要由CSDN通过智能技术生成

问题背景:
项目因为要使用redis锁,所以引入了redisson,配置的是redisson-spring-boot依赖,引入了以后web项目正常,但是manage项目会有cpu波动,查看波动时候的线程情况是redisson一个线程引起的,另外在改回原生redisson依赖后波动消失

在这里插入图片描述
问题点:
1、为什么引入Springboot-redisson后manage飙升了,但是web没有动静
2、用了原生redisson后又不飙升了

首先对比错误日志发现RedisMessageListenerContainer类是主要执行类在创建线程,查看这个类的内容发现是在RedisHttpSessionConfiguration类内完成组件化的,而RedisHttpSessionConfiguration配置类的引入是Spring-session中的EnableRedisHttpSession注解,而web项目和redis项目的不同,manage相对于web多了redis-session的配置及依赖,那么是不是Springboot-redisson对这个组件化过程或者执行过程有特别的实现,我们从这里开始入手

manage是公司内部使用系统,使用了内部权限系统,所以配置了session共享

<dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session-data-redis</artifactId>
</dependency>
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 600)
public class ManageSessionConfig {
    
}

翻看@EnableRedisHttpSession源码,发现主要是引入RedisHttpSessionConfiguration配置类,这个配置类主要做的工作是初始化RedisIndexedSessionRepository监听器和RedisMessageListenerContainer监听器容器,这里的RedisMessageListenerContainer监听器就和上面的异常线程日志对上了,这里主要监听了什么内容及做了什么工作

在这里插入图片描述
上图可以看出是在这里设置了监听内容,断点进入

在这里插入图片描述
可以看出它监听了database0的key删除和过期事件,但是这里有个疑问为什么监听的是database0,我们apollo配置的是11,找见监听器初始化时设置db的地方断点

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值