Spring超出最大会话数(Max sessions limit reached: 10000)
一.错误信息描述
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; }
到此这篇关于Spring超出最大会话数(Max sessions limit reached: 10000)的文章就介绍到这了,更多相关Spring超出最大会话数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
java集合之CopyOnWriteArrayList源码解析
这篇文章主要介绍了java集合之CopyOnWriteArrayList源码解析,容器array是volatile修饰的,即set和get方法都是线程安全的,整个添加过程上了锁,所以整体是通过volatile和lock来保证的线程安全,需要的朋友可以参考下2023-12-12
最新评论