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”幾乎沒有找到有價值的文章。
三.錯誤原因
我們項目的配置文件、代碼都都沒有做最大會話數(shù)配置,那么就應(yīng)該是spring的默認配置,根據(jù)錯誤信息“org.springframework.web.server.session.InMemoryWebSessionStore$InMemoryWebSession.checkMaxSessionsLimit(InMemoryWebSessionStore.java:276)”找到方法,進入到里面看到如下代碼,檢查當(dāng)前會話大于this.maxSessions就拋出該異常
然后查看this.maxSessions的值,發(fā)現(xiàn)默認值是10000
四.解決方案
知道了錯誤發(fā)生的原因,那么解決思路就是調(diào)整maxSessions的值,在項目啟動的時候創(chuàng)建一個Bean,修改maxSessions的值。
@Bean public WebSessionManager webSessionManager () { DefaultWebSessionManager webSessionManager = new DefaultWebSessionManager(); InMemoryWebSessionStore store = new InMemoryWebSessionStore(); store.setMaxSessions(100000); webSessionManager.setSessionStore(store); return webSessionManager; }
五.驗證
將maxSessions設(shè)置為1“store.setMaxSessions(1);”來測試,重啟服務(wù),第二個用戶登錄就觸發(fā)了異常,說明該設(shè)置已生效
接著將maxSessions設(shè)置為100000(根據(jù)自己實際需求設(shè)置),再做性能測試,就沒有這個問題了。另外,由于存儲的會話增加了,同時需要適當(dāng)?shù)恼{(diào)整jvm內(nèi)存 -Xmx的值,以避免內(nèi)存溢出,或者頻繁的gc導(dǎo)致新能下降。
六.其它
另外,會話存儲的有效時間默認是30分鐘
可按需做調(diào)整
@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; }
到此這篇關(guān)于Spring超出最大會話數(shù)(Max sessions limit reached: 10000)的文章就介紹到這了,更多相關(guān)Spring超出最大會話數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot使用maven實現(xiàn)多環(huán)境運行和打包的操作步驟
在開發(fā)過程中,需要不斷進行環(huán)境的切換和打包部署,maven提供了多環(huán)境配置,可以方便實現(xiàn)不同環(huán)境的配置切換和打包,本文通過代碼示例給大家介紹的非常詳細,需要的朋友可以參考下2024-04-04Spring事務(wù)框架之TransactionStatus源碼解析
這篇文章主要為大家介紹了Spring事務(wù)框架之TransactionStatus源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08Java 連接Access數(shù)據(jù)庫的兩種方式
這篇文章主要介紹了Java 連接Access數(shù)據(jù)庫的兩種方式,本文著重講解使用JDBC連接操作Access數(shù)據(jù)庫,需要的朋友可以參考下2015-06-06Java組件FileUpload上傳文件實現(xiàn)代碼
這篇文章主要為大家詳細介紹了Java組件FileUpload上傳文件實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06