java - 正常的應(yīng)用多久一次Full GC?
問(wèn)題描述
我查看我們服務(wù)器的狀態(tài),半個(gè)月發(fā)生了900+次full gc,大約20分鐘一次full gc,這是正常的嗎?或者說(shuō)優(yōu)化到多久一次會(huì)比較合理?
問(wèn)題解答
回答1:雖然沒(méi)有優(yōu)化過(guò)。不過(guò)覺(jué)得這個(gè)需要按照實(shí)際的業(yè)務(wù)需求和業(yè)務(wù)能力去做支撐.才好優(yōu)化。
回答2:看java應(yīng)用的heap大小以及qps,不過(guò)初步看20分鐘一次的full gc,貌似不大正常
回答3:jvm的優(yōu)化談起來(lái)可以講幾個(gè)小時(shí),這里簡(jiǎn)單的給你點(diǎn)意見(jiàn),不系統(tǒng)的展開(kāi)說(shuō)。
其一 :你的問(wèn)題是full gc 頻繁,看下總內(nèi)存和老年代設(shè)置的是否太小了。主要是看參數(shù) -Xmx , -Xmn. 若是太小的話(huà),必然會(huì)gc頻繁。
其二:添加以下參數(shù) -verbose.gc -XX:+PrintGC -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -XX:+PrintTenuringDistribution -XX:+PrintGCApplicationStoppedTime -XX:+PrintTenuringDistribution -Xloggc:/data/log/xxx/xxx-gc.log -XX:+PrintGCDetails查看每次gc ,老年代還剩余多少空間,一般來(lái)說(shuō),老年代的空間設(shè)置為gc后內(nèi)存的2-2.5倍是一個(gè)較為合理的數(shù)值。同時(shí)通過(guò)這個(gè)日志可以看到是否大量的對(duì)象沒(méi)有在新生代充分的gc掉就進(jìn)入老生代。原本可以通過(guò)新生代回收的對(duì)象進(jìn)入老年代的話(huà)必然會(huì)full gc 頻繁
其三 : 代碼原因 dump 內(nèi)存 jmap -dump:live,format=b,file=xx.bin [pid]然后通過(guò)MAT(http://www.eclipse.org/mat/)工具來(lái)看具體是哪塊大內(nèi)存沒(méi)有被釋放
相關(guān)文章:
1. javascript - 百度echarts series數(shù)據(jù)更新問(wèn)題2. MySQL客戶(hù)端吃掉了SQL注解?3. java - 我設(shè)置了cookie的max age,但是cookie依然在關(guān)閉游覽器后消失了4. css3 - [CSS] 動(dòng)畫(huà)效果 3D翻轉(zhuǎn)bug5. javascript - JS設(shè)置Video視頻對(duì)象的currentTime時(shí)出現(xiàn)了問(wèn)題,IE,Edge,火狐,都可以設(shè)置,反而chrom卻...6. python小白的基礎(chǔ)問(wèn)題 關(guān)于while循環(huán)的嵌套7. java固定鍵值轉(zhuǎn)換,使用枚舉實(shí)現(xiàn)字典?8. php自學(xué)從哪里開(kāi)始?9. phpstady在win10上運(yùn)行10. 求大神幫我看看是哪里寫(xiě)錯(cuò)了 感謝細(xì)心解答
