一.错误信息描述
java.lang.IllegalStateException: Max sessions limit reached: 10000
at org.springframework.web.server.session.InMemoryWebSessionStore$InMemoryWebSession.checkMaxSessionsLimit(InMemoryWebSessionStore.java:276)
Suppressed: reactor.core.publisher.FluxOnAssembly$OnAssemblyException:
Error has been observed at the following site(s):
从主要错误信息可以看出,是超出了最大会话限制数10000。
二.触发场景
在常规的系统使用中,基本很难触发这个问题,我们是在一次性能测试的时候模拟100个用户并发请求,执行到八十几个用户的时候,就触发了该异常。所以在搜索引擎上搜索错误信息“Max sessions limit reached: 10000”几乎没有找到有价值的文章。
三.错误原因
我们项目的配置文件、代码都都没有做最大会话数配置,那么就应该是spring的默认配置,根据错误信息“org.springframework.web.server.session.InMemoryWebSessionStore$InMemoryWebSession.checkMaxSessionsLimit(InMemoryWebSessionStore.java:276)”找到方法,进入到里面看到如下代码,检查当前会话大于this.maxSessions就抛出该异常
然后查看this.maxSessions的值,发现默认值是10000
四.解决方案
知道了错误发生的原因,那么解决思路就是调整maxSessions的值,在项目启动的时候创建一个Bean,修改maxSessions的值。
@Bean
public WebSessionManager webSessionManager () {
DefaultWebSessionManager webSessionManager = new DefaultWebSessionManager();
InMemoryWebSessionStore store = new InMemoryWebSessionStore();
store.setMaxSessions(100000);
webSessionManager.setSessionStore(store);
return webSessionManager;
}
五.验证
将maxSessions设置为1“store.setMaxSessions(1);”来测试,重启服务,第二个用户登录就触发了异常,说明该设置已生效
接着将maxSessions设置为100000(根据自己实际需求设置),再做性能测试,就没有这个问题了。另外,由于存储的会话增加了,同时需要适当的调整jvm内存 -Xmx的值,以避免内存溢出,或者频繁的gc导致新能下降。
六.其它
另外,会话存储的有效时间默认是30分钟
可按需做调整
@Bean
public WebSessionManager webSessionManager() {
DefaultWebSessionManager webSessionManager = new DefaultWebSessionManager();
InMemoryWebSessionStore store = new InMemoryWebSessionStore();
store.setMaxSessions(100000);
//会话的有效时间默认30分钟,可以通过下面的方式修改
store.createWebSession().subscribe(
session -> {
session.setMaxIdleTime(Duration.ofMinutes(60L));
},
error -> LogUtils.error("create session error", error)
);
webSessionManager.setSessionStore(store);
return webSessionManager;
}