以前公司做了一個web項目。發佈以後,隨着訪問量的逐漸增大,發現JVM的內存使用比較多,full gc比較頻繁,而且full gc後old區的大小
變化不大。剛開始以爲是JVM虛擬機的各項參數配置的不合理,我們就對JVM虛擬機的參數進行調整,調整後發現GC還是非常的頻繁。
funll GC頻繁非常影響性能,我們把jvm的heapdump( Java 堆棧的快照)文件導出來,採用IBM HeapAnalyzer 的分析工具進行分析。經
過分析發現堆中存在很多session對象。這些session對象佔用空間比較大大,而且佔堆內存的比例很大。很明顯問題是出現在session上面。
因爲客戶端訪問時,當服務端中沒有該客戶端的session,將會生成session對象,由於項目中的session過期時間設置的比較大,所以當訪問
量比較大的時候,產生的session對象就非常的多,導致佔用了很大的堆內存。
以前session設置爲30分鐘,後來設置爲1分鐘,代碼如下:
<!-- 設置session失效,單位分 --> <session-config> <session-timeout>1</session-timeout> session-config>
把session過期時間設置爲1分鐘後,進行壓力測試,發現full gc減少了很多,而且JVM的內存的用量也減少了很多。從這個結果得出結論設置
合理的session過期時間是非常有必要的。
自己考慮設置一個合理的過期時間。注:由於這個web工程中沒有任何信息放入到session中,所以可以設置session時間很短。如果session中放了信息,那麼大家就需要