tomcat - java數據存放問題
問題描述
如題,有登陸的系統,老項目沒cache(我沒權利去加),但是不同的服務都要使用先前http請求到的數據(由用戶區分),想把它保存起來避免每次重復發http請求浪費資源。
后臺springmvc
目前我想到3個方法:
1.丟session里面(HttpSessionListener),應該最簡單,但不知道潛在問題2.丟threadlocal里面(controller搞個static 的threadlocal的變量,或者寫個contextholder)3.controller搞個ConcurrentHashMap的成員,把數據按<用戶id,http請求拿到的數據>放進去.但是這個肯定不可行,可能會導致堆區OOF
說說第2個方案可能存在的問題。1.網上說的可能內存泄露問題,導致PermGen出現OOF,原文連接ThreadLocal 內存泄露的實例分析
我不確定是否會出現問題(原文有點看不懂),因為ThreadLocalMap的set具有保護機制
2.會不會出現請求線程里面的數據串了,比如1個請求線程同時服務兩個用戶(A和B)請求,B把自己的數據放到請求線程,覆蓋了A的,而請求線程服務A的時候,拿到了B的數據。。
問題解答
回答1:方法1是最簡單、最常用的,如果用戶量太大,或者做了負載均衡,就要實現集中存儲的Session,有很多現成的方案可以支持集中存儲的HttpSession的,存Redis、MongoDB、MySQL的都有,GitHub上搜一下。
方法2不解決問題,主要是因為用戶登錄后,多次請求可能會落在多個線程里。你說的第二點也是理由。
方法3也是一種實現方式,其實Tomcat的HttpSession就是用ConcurrentHashMap實現的(只是它用sessionId而不是用userId做key),但要注意的一點是,你必須自己管理Map中每個Key-Value的生命周期,例如Session超時了要及時remove掉。
相關文章:
1. html5和Flash對抗是什么情況?2. html5 - datatables 加載不出來數據。3. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????4. 利用IPMI遠程安裝centos報錯!5. node.js - mongodb查找子對象的名稱為某個值的對象的方法6. 運行python程序時出現“應用程序發生異常”的內存錯誤?7. 測試自動化html元素選擇器元素ID或DataAttribute [關閉]8. javascript - QQ第三方登錄的問題9. javascript - 在 model里定義的 引用表模型時,model為undefined。10. spring-mvc - spring-session-redis HttpSessionListener失效

網公網安備