jvm哪些情況會導致 年輕代 越過 15年齡的限制 去到老年代

1.是哪些參數控制了 old:young 和 eden : from 和 年輕代 到 老年代的年齡限制的

2.哪些情況會導致 年輕代 越過 15年齡的限制 去到老年代

 

大家應該知道 jvm 有年輕代 老年代 方法區等等 大概組成部分 如果不清楚,我這裏給一張圖

這裏以jdk8 爲基準

–XX:NewRatio:默認 -XX:NewRatio=2

    old:YOUNG = 2

–XX:SurvivorRatio   默認 -XX:SurvivorRatio=8

    Edem : from : to = 8 : 1 : 1

這裏可能會有人說 這個默認參數是怎麼得到的

正好回答一下 圖片中的兩個問題

1.是哪些參數控制了 old:young 和 eden : from 和 年輕代 到 老年代的年齡限制的

2.哪些情況會導致 年輕代 越過 15年齡的限制 去到老年代

#看old : young 
jinfo -flag NewRatio 21030
#看eden: from
jinfo -flag SurvivorRatio 21030
#看年輕代 到 老年代的年齡限制
jinfo -flag MaxTenuringThreshold  21030

已經解答了 第一個問題

第二個有哪些情況會出現這種情況呢

1.新生代垃圾回收之後 因爲存活對象過多,eden空間不夠了,導致對象都到老年代了 (新生代要保證空間足夠)

2.特別大的超大對象直接不經過新生代到老年代 (超過from 區 的50%)

3.動態對象年齡判斷機制

4.空間擔保機制

 

 

額外插一句:

寫這個的時候 朋友出現了以下問題:

Caused by: com.ibatis.common.jdbc.exception.NestedSQLException:   
--- The error occurred in mapping/Menu_SqlMap.xml.  
--- The error occurred while executing query.  
--- Check the select id, parentid, name, url, per...

這個錯誤在網上搜索沒什麼用,說是insert有問題 等等

我這裏的問題是查詢太慢了,慢sql 導致

這裏就說到 怎麼找到慢sql

請使用 root用戶 或者有相應權限的

#mysql查看正在執行的sql語句
select * from information_schema.`PROCESSLIST` where info is not null;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章