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. 為什么我ping不通我的docker容器呢???2. 關于docker下的nginx壓力測試3. debian - docker依賴的aufs-tools源碼哪里可以找到啊?4. angular.js - angular內容過長展開收起效果5. javascript - webpack熱加載配置不生效6. docker start -a dockername 老是卡住,什么情況?7. javascript - js代碼獲取驗證碼倒計時問題8. dockerfile - [docker build image失敗- npm install]9. 主從備份 - 跪求mysql 高可用主從方案10. java - instance method中 static后的<K>是什么意思?
