tomcat - java數(shù)據(jù)存放問題
問題描述
如題,有登陸的系統(tǒng),老項目沒cache(我沒權(quán)利去加),但是不同的服務(wù)都要使用先前http請求到的數(shù)據(jù)(由用戶區(qū)分),想把它保存起來避免每次重復(fù)發(fā)http請求浪費資源。
后臺springmvc
目前我想到3個方法:
1.丟session里面(HttpSessionListener),應(yīng)該最簡單,但不知道潛在問題2.丟threadlocal里面(controller搞個static 的threadlocal的變量,或者寫個contextholder)3.controller搞個ConcurrentHashMap的成員,把數(shù)據(jù)按<用戶id,http請求拿到的數(shù)據(jù)>放進(jìn)去.但是這個肯定不可行,可能會導(dǎo)致堆區(qū)OOF
說說第2個方案可能存在的問題。1.網(wǎng)上說的可能內(nèi)存泄露問題,導(dǎo)致PermGen出現(xiàn)OOF,原文連接ThreadLocal 內(nèi)存泄露的實例分析
我不確定是否會出現(xiàn)問題(原文有點看不懂),因為ThreadLocalMap的set具有保護(hù)機制
2.會不會出現(xiàn)請求線程里面的數(shù)據(jù)串了,比如1個請求線程同時服務(wù)兩個用戶(A和B)請求,B把自己的數(shù)據(jù)放到請求線程,覆蓋了A的,而請求線程服務(wù)A的時候,拿到了B的數(shù)據(jù)。。
問題解答
回答1:方法1是最簡單、最常用的,如果用戶量太大,或者做了負(fù)載均衡,就要實現(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掉。
相關(guān)文章:
1. android - weex 項目createInstanceReferenceError: Vue is not defined2. PHPExcel表格導(dǎo)入數(shù)據(jù)庫怎么導(dǎo)入3. pdo 寫入到數(shù)據(jù)庫的內(nèi)容為中文的時候?qū)懭雭y碼4. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點5. javascript - 如圖,百度首頁,查看源代碼為什么什么都沒有?6. vue2.0+webpack 如何使用bootstrap?7. PHP類封裝的插入數(shù)據(jù),總是插入不成功,返回false;8. mac連接阿里云docker集群,已經(jīng)卡了2天了,求問?9. 微信渠道二維碼怎么使用?10. 我畢業(yè)以后在工作之余學(xué)了 PHP,都是自學(xué) 現(xiàn)在在找這方面的工作 求前輩指導(dǎo)學(xué)習(xí)方向 工作常用的知識
