Spring超出最大會(huì)話數(shù)(Max?sessions?limit?reached:?10000)
一.錯(cuò)誤信息描述
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):
從主要錯(cuò)誤信息可以看出,是超出了最大會(huì)話限制數(shù)10000。
二.觸發(fā)場(chǎng)景
在常規(guī)的系統(tǒng)使用中,基本很難觸發(fā)這個(gè)問(wèn)題,我們是在一次性能測(cè)試的時(shí)候模擬100個(gè)用戶并發(fā)請(qǐng)求,執(zhí)行到八十幾個(gè)用戶的時(shí)候,就觸發(fā)了該異常。所以在搜索引擎上搜索錯(cuò)誤信息“Max sessions limit reached: 10000”幾乎沒(méi)有找到有價(jià)值的文章。
三.錯(cuò)誤原因
我們項(xiàng)目的配置文件、代碼都都沒(méi)有做最大會(huì)話數(shù)配置,那么就應(yīng)該是spring的默認(rèn)配置,根據(jù)錯(cuò)誤信息“org.springframework.web.server.session.InMemoryWebSessionStore$InMemoryWebSession.checkMaxSessionsLimit(InMemoryWebSessionStore.java:276)”找到方法,進(jìn)入到里面看到如下代碼,檢查當(dāng)前會(huì)話大于this.maxSessions就拋出該異常
然后查看this.maxSessions的值,發(fā)現(xiàn)默認(rèn)值是10000
四.解決方案
知道了錯(cuò)誤發(fā)生的原因,那么解決思路就是調(diào)整maxSessions的值,在項(xiàng)目啟動(dòng)的時(shí)候創(chuàng)建一個(gè)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);”來(lái)測(cè)試,重啟服務(wù),第二個(gè)用戶登錄就觸發(fā)了異常,說(shuō)明該設(shè)置已生效
接著將maxSessions設(shè)置為100000(根據(jù)自己實(shí)際需求設(shè)置),再做性能測(cè)試,就沒(méi)有這個(gè)問(wèn)題了。另外,由于存儲(chǔ)的會(huì)話增加了,同時(shí)需要適當(dāng)?shù)恼{(diào)整jvm內(nèi)存 -Xmx的值,以避免內(nèi)存溢出,或者頻繁的gc導(dǎo)致新能下降。
六.其它
另外,會(huì)話存儲(chǔ)的有效時(shí)間默認(rèn)是30分鐘
可按需做調(diào)整
@Bean public WebSessionManager webSessionManager() { DefaultWebSessionManager webSessionManager = new DefaultWebSessionManager(); InMemoryWebSessionStore store = new InMemoryWebSessionStore(); store.setMaxSessions(100000); //會(huì)話的有效時(shí)間默認(rèn)30分鐘,可以通過(guò)下面的方式修改 store.createWebSession().subscribe( session -> { session.setMaxIdleTime(Duration.ofMinutes(60L)); }, error -> LogUtils.error("create session error", error) ); webSessionManager.setSessionStore(store); return webSessionManager; }
到此這篇關(guān)于Spring超出最大會(huì)話數(shù)(Max sessions limit reached: 10000)的文章就介紹到這了,更多相關(guān)Spring超出最大會(huì)話數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot使用maven實(shí)現(xiàn)多環(huán)境運(yùn)行和打包的操作步驟
在開(kāi)發(fā)過(guò)程中,需要不斷進(jìn)行環(huán)境的切換和打包部署,maven提供了多環(huán)境配置,可以方便實(shí)現(xiàn)不同環(huán)境的配置切換和打包,本文通過(guò)代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04利用MyBatis進(jìn)行不同條件的like模糊查詢的方法
這篇文章主要介紹了利用MyBatis進(jìn)行不同條件的like模糊查詢,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08Java實(shí)現(xiàn)軟件運(yùn)行時(shí)啟動(dòng)信息窗口的方法
這篇文章主要介紹了Java實(shí)現(xiàn)軟件運(yùn)行時(shí)啟動(dòng)信息窗口的方法,比較實(shí)用的功能,需要的朋友可以參考下2014-08-08Spring事務(wù)框架之TransactionStatus源碼解析
這篇文章主要為大家介紹了Spring事務(wù)框架之TransactionStatus源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08Java 連接Access數(shù)據(jù)庫(kù)的兩種方式
這篇文章主要介紹了Java 連接Access數(shù)據(jù)庫(kù)的兩種方式,本文著重講解使用JDBC連接操作Access數(shù)據(jù)庫(kù),需要的朋友可以參考下2015-06-06Java組件FileUpload上傳文件實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了Java組件FileUpload上傳文件實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06Docker?快速部署Springboot項(xiàng)目超詳細(xì)最新版
這篇文章主要介紹了Docker?快速部署Springboot項(xiàng)目超詳細(xì)最新版的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04