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, 这样很少会有大文件直接移动到老年代里面去了。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值