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;