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;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值