jvm-优化数据分析

运行GC的时候,会把应用操作的线程停止掉,客户端就会有停顿,卡顿,

jvm调优目的是,减少gc的次数,和停顿时间(full gc 主要)

如果当前对象,大于是s1对象的50% 该数据直接挪动到老年代

数据量分析:

如果一个给jvm虚拟机分配的内存是3个G,那么默认老年代会分2g,eden区分800m,s1 100m. s2 100m 

800/16=13秒,, 当时eden区域的数据存满之后,会执行minorGC ,但是只会执行前12秒  已经死亡的对象,第13秒进来的对象,还存活无法被垃圾回收。所以第13秒的对象会移动到  s1 内存区域,让再过13秒minor GC 再次清理,会把第13秒的数据移动到 s2,同时清理 s1的数据。但是当移动到s1,或者s2的数据,大于50%时,会把数据直接移动老年代。 l老年代的数据=2*1024m

等过10几分钟,full GC清除老年代,FULL GC正常来说一天或者 几天清除一次,是正常的

fullGC  清除时,会暂停用户正在响应的线程,用户会体现出来卡顿现象,所以减少 fullGC的清除时间,和清除次数,是优化的重点

重点:可以设置,jvm虚拟机分配内存3g,新生代 2g, 这样很少会有大文件直接移动到老年代里面去了。

发布了143 篇原创文章 · 获赞 41 · 访问量 59万+

猜你喜欢

转载自blog.csdn.net/qq_29257691/article/details/103665539