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. windows誤人子弟啊2. php傳對應的id值為什么傳不了啊有木有大神會的看我下方截圖3. 如何用筆記本上的apache做微信開發的服務器4. python - linux 下用wsgifunc 運行web.py該如何修改代碼5. 關于mysql聯合查詢一對多的顯示結果問題6. 實現bing搜索工具urlAPI提交7. 冒昧問一下,我這php代碼哪里出錯了???8. mysql優化 - MySQL如何為配置表建立索引?9. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)10. 數據庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。
