Spring超出最大會話數(shù)(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):
從主要錯誤信息可以看出,是超出了最大會話限制數(shù)10000。
二.觸發(fā)場景
在常規(guī)的系統(tǒng)使用中,基本很難觸發(fā)這個問題,我們是在一次性能測試的時候模擬100個用戶并發(fā)請求,執(zhí)行到八十幾個用戶的時候,就觸發(fā)了該異常。所以在搜索引擎上搜索錯誤信息“Max sessions limit reached: 10000”幾乎沒有找到有價值的文章。
三.錯誤原因
我們項(xiàng)目的配置文件、代碼都都沒有做最大會話數(shù)配置,那么就應(yīng)該是spring的默認(rèn)配置,根據(jù)錯誤信息“org.springframework.web.server.session.InMemoryWebSessionStore$InMemoryWebSession.checkMaxSessionsLimit(InMemoryWebSessionStore.java:276)”找到方法,進(jìn)入到里面看到如下代碼,檢查當(dāng)前會話大于this.maxSessions就拋出該異常

然后查看this.maxSessions的值,發(fā)現(xiàn)默認(rèn)值是10000

四.解決方案
知道了錯誤發(fā)生的原因,那么解決思路就是調(diào)整maxSessions的值,在項(xiàng)目啟動的時候創(chuàng)建一個Bean,修改maxSessions的值。
@Bean
public WebSessionManager webSessionManager () {
DefaultWebSessionManager webSessionManager = new DefaultWebSessionManager();
InMemoryWebSessionStore store = new InMemoryWebSessionStore();
store.setMaxSessions(100000);
webSessionManager.setSessionStore(store);
return webSessionManager;
}五.驗(yàn)證
將maxSessions設(shè)置為1“store.setMaxSessions(1);”來測試,重啟服務(wù),第二個用戶登錄就觸發(fā)了異常,說明該設(shè)置已生效

接著將maxSessions設(shè)置為100000(根據(jù)自己實(shí)際需求設(shè)置),再做性能測試,就沒有這個問題了。另外,由于存儲的會話增加了,同時需要適當(dāng)?shù)恼{(diào)整jvm內(nèi)存 -Xmx的值,以避免內(nèi)存溢出,或者頻繁的gc導(dǎo)致新能下降。
六.其它
另外,會話存儲的有效時間默認(rèn)是30分鐘

可按需做調(diào)整
@Bean
public WebSessionManager webSessionManager() {
DefaultWebSessionManager webSessionManager = new DefaultWebSessionManager();
InMemoryWebSessionStore store = new InMemoryWebSessionStore();
store.setMaxSessions(100000);
//會話的有效時間默認(rèn)30分鐘,可以通過下面的方式修改
store.createWebSession().subscribe(
session -> {
session.setMaxIdleTime(Duration.ofMinutes(60L));
},
error -> LogUtils.error("create session error", error)
);
webSessionManager.setSessionStore(store);
return webSessionManager;
}到此這篇關(guān)于Spring超出最大會話數(shù)(Max sessions limit reached: 10000)的文章就介紹到這了,更多相關(guān)Spring超出最大會話數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot使用maven實(shí)現(xiàn)多環(huán)境運(yùn)行和打包的操作步驟
在開發(fā)過程中,需要不斷進(jìn)行環(huán)境的切換和打包部署,maven提供了多環(huán)境配置,可以方便實(shí)現(xiàn)不同環(huán)境的配置切換和打包,本文通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04
利用MyBatis進(jìn)行不同條件的like模糊查詢的方法
這篇文章主要介紹了利用MyBatis進(jìn)行不同條件的like模糊查詢,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
Java實(shí)現(xiàn)軟件運(yùn)行時啟動信息窗口的方法
這篇文章主要介紹了Java實(shí)現(xiàn)軟件運(yùn)行時啟動信息窗口的方法,比較實(shí)用的功能,需要的朋友可以參考下2014-08-08
Spring事務(wù)框架之TransactionStatus源碼解析
這篇文章主要為大家介紹了Spring事務(wù)框架之TransactionStatus源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
Java 連接Access數(shù)據(jù)庫的兩種方式
這篇文章主要介紹了Java 連接Access數(shù)據(jù)庫的兩種方式,本文著重講解使用JDBC連接操作Access數(shù)據(jù)庫,需要的朋友可以參考下2015-06-06
Java組件FileUpload上傳文件實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了Java組件FileUpload上傳文件實(shí)現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06
Docker?快速部署Springboot項(xiàng)目超詳細(xì)最新版
這篇文章主要介紹了Docker?快速部署Springboot項(xiàng)目超詳細(xì)最新版的相關(guān)資料,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04

