tomcat - java數(shù)據(jù)存放問題
問題描述
如題,有登陸的系統(tǒng),老項目沒cache(我沒權利去加),但是不同的服務都要使用先前http請求到的數(shù)據(jù)(由用戶區(qū)分),想把它保存起來避免每次重復發(fā)http請求浪費資源。
后臺springmvc
目前我想到3個方法:
1.丟session里面(HttpSessionListener),應該最簡單,但不知道潛在問題2.丟threadlocal里面(controller搞個static 的threadlocal的變量,或者寫個contextholder)3.controller搞個ConcurrentHashMap的成員,把數(shù)據(jù)按<用戶id,http請求拿到的數(shù)據(jù)>放進去.但是這個肯定不可行,可能會導致堆區(qū)OOF
說說第2個方案可能存在的問題。1.網(wǎng)上說的可能內存泄露問題,導致PermGen出現(xiàn)OOF,原文連接ThreadLocal 內存泄露的實例分析
我不確定是否會出現(xiàn)問題(原文有點看不懂),因為ThreadLocalMap的set具有保護機制
2.會不會出現(xiàn)請求線程里面的數(shù)據(jù)串了,比如1個請求線程同時服務兩個用戶(A和B)請求,B把自己的數(shù)據(jù)放到請求線程,覆蓋了A的,而請求線程服務A的時候,拿到了B的數(shù)據(jù)。。
問題解答
回答1:方法1是最簡單、最常用的,如果用戶量太大,或者做了負載均衡,就要實現(xiàn)集中存儲的Session,有很多現(xiàn)成的方案可以支持集中存儲的HttpSession的,存Redis、MongoDB、MySQL的都有,GitHub上搜一下。
方法2不解決問題,主要是因為用戶登錄后,多次請求可能會落在多個線程里。你說的第二點也是理由。
方法3也是一種實現(xiàn)方式,其實Tomcat的HttpSession就是用ConcurrentHashMap實現(xiàn)的(只是它用sessionId而不是用userId做key),但要注意的一點是,你必須自己管理Map中每個Key-Value的生命周期,例如Session超時了要及時remove掉。
相關文章:
1. html - vue項目中用到了elementUI問題2. mysql scripts提示 /usr/bin/perl: bad interpreter3. showpassword里的this 是什么意思?代表哪個元素4. css3 - border-bottom 的長度可否超過盒子的寬度呢?實現(xiàn)如下圖效果。(我的書下面的線)5. android - 用textview顯示html時如何寫imagegetter獲取網(wǎng)絡圖片6. 對mysql某個字段監(jiān)控的功能7. css3 - css怎么實現(xiàn)圖片環(huán)繞的效果8. javascript - 原生canvas中如何獲取到觸摸事件的canvas內坐標?9. JavaScript事件10. mysql優(yōu)化 - mysql EXPLAIN之后怎么看結果進行優(yōu)化 ?
