JSP session配置對(duì)web應(yīng)用的影響
以前公司做了一個(gè)web項(xiàng)目。發(fā)布以后,隨著訪問(wèn)量的逐漸增大,發(fā)現(xiàn)JVM的內(nèi)存使用比較多,full gc比較頻繁,而且full gc后old區(qū)的大小變化不大。剛開(kāi)始以為是JVM虛擬機(jī)的各項(xiàng)參數(shù)配置的不合理,我們就對(duì)JVM虛擬機(jī)的參數(shù)進(jìn)行調(diào)整,調(diào)整后發(fā)現(xiàn)GC還是非常的頻繁。
funll GC頻繁非常影響性能,我們把jvm的heapdump( Java 堆棧的快照)文件導(dǎo)出來(lái),采用IBM HeapAnalyzer 的分析工具進(jìn)行分析。經(jīng)過(guò)分析發(fā)現(xiàn)堆中存在很多session對(duì)象。這些session對(duì)象占用空間比較大大,而且占堆內(nèi)存的比例很大。很明顯問(wèn)題是出現(xiàn)在session上面。
因?yàn)榭蛻舳嗽L問(wèn)時(shí),當(dāng)服務(wù)端中沒(méi)有該客戶端的session,將會(huì)生成session對(duì)象,由于項(xiàng)目中的session過(guò)期時(shí)間設(shè)置的比較大,所以當(dāng)訪問(wèn)量比較大的時(shí)候,產(chǎn)生的session對(duì)象就非常的多,導(dǎo)致占用了很大的堆內(nèi)存。
以前session設(shè)置為30分鐘,后來(lái)設(shè)置為1分鐘,代碼如下:
!-- 設(shè)置session失效,單位分 -->
session-config>
session-timeout>1/session-timeout>
session-config>
把session過(guò)期時(shí)間設(shè)置為1分鐘后,進(jìn)行壓力測(cè)試,發(fā)現(xiàn)full gc減少了很多,而且JVM的內(nèi)存的用量也減少了很多。從這個(gè)結(jié)果得出結(jié)論設(shè)置
合理的session過(guò)期時(shí)間是非常有必要的。
注:由于這個(gè)web工程中沒(méi)有任何信息放入到session中,所以可以設(shè)置session時(shí)間很短。如果session中放了信息,那么大家就需要
自己考慮設(shè)置一個(gè)合理的過(guò)期時(shí)間。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
您可能感興趣的文章:- jsp編程中session的用法實(shí)例分析
- jsp中Action使用session方法實(shí)例分析
- JSP動(dòng)態(tài)生成驗(yàn)證碼存儲(chǔ)在session作用范圍內(nèi)
- jsp獲取action傳來(lái)的session和session清空以及判斷
- jsp和asp.net共享session值示例代碼
- Jsp中解決session過(guò)期跳轉(zhuǎn)到登陸頁(yè)面并跳出iframe框架的方法
- JSP中 Session和作用域的使用
- jsp中session過(guò)期設(shè)置及web.xml配置學(xué)習(xí)
- jsp 對(duì)request.getSession(false)的理解(附程序員常疏忽的一個(gè)漏洞)
- JSP由淺入深(9)—— JSP Sessions