java年轻代频繁gc_年轻代频繁ParNew GC,导致http服务rt飙高

背景介绍

某日下午大约四点多,接到合作方消息,线上环境,我这边维护的某http服务突然大量超时(对方超时时间设置为300ms),我迅速到鹰眼平台开启采样,发现该服务平均QPS到了120左右,平均RT在2秒多到3秒,部分毛刺高达5到6秒(正常时候在60ms左右)。

qps情况:

747b936b5a2ba7c4a5c563c2b3e6f6fa.png

rt情况

8c6e586fec94b45f688fdbb182a9122c.png

问题解决

该服务是一个对内的运营平台服务(只部署了两台docker)预期qps个位数,近期没做过任何的线上发布,核心操作是整合查询数据库,一次请求最多涉及40次左右的DB查询,最终查询结果为一个多层树形结构,一个响应体大约50K。之前口头跟调用方约定要做缓存,现在看到QPS在120左右,(QPS证明没有做缓存),遂要求对方做缓存,降低QPS。后QPS降到80以内,rt恢复正常(平均60ms),最终QPS一直降到40(后续需要推动调用方上缓存,保证QPS在个位数)。

问题定位

由于该服务核心操作是查询数据库,且一次请求有40次DB query,遂首先排查是否慢sql导致&

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ParNew GC是JVM中的一种垃圾回收器,它是基于并行垃圾回收算法的,主要用于新生的垃圾回收。ParNew GC在垃圾回收时使用多个线程并行地进行垃圾回收,以达到快速回收内存的目的。 ParNew GC与Serial GC的主要区别是:ParNew GC是使用多线程并行处理的,而Serial GC是单线程处理的。在垃圾回收时,ParNew GC会将堆内存分成多个区域,然后使用多个线程并行地进行垃圾回收。这样能够有效地减少垃圾回收的时间,提高应用程序的吞吐量。 ParNew GC的垃圾回收过程分为以下几个阶段: 1. 初始标记阶段(Initial Mark):在这个阶段中,ParNew GC会暂停应用程序,然后标记出所有根对象以及所有直接引用的对象。 2. 并发标记阶段(Concurrent Mark):在这个阶段中,ParNew GC会使用多个线程并发地标记所有存活的对象。这个阶段与应用程序并发执行,所以不会造成应用程序的停顿。 3. 重新标记阶段(Remark):在这个阶段中,ParNew GC会再次暂停应用程序,然后标记出在并发标记阶段中被引用的对象。 4. 并发清理阶段(Concurrent Cleanup):在这个阶段中,ParNew GC会使用多个线程并发地清理无用的对象。这个阶段与应用程序并发执行,所以不会造成应用程序的停顿。 ParNew GC的优点是速度快,因为它使用多线程并行处理。另外,它的停顿时间相对较短,对于对响应时间有要求的应用程序来说,ParNew GC是一个不错的选择。但是,ParNew GC也有一些缺点,比如它需要更多的内存来存储垃圾回收信息,而且需要更多的CPU时间来进行垃圾回收。另外,ParNew GC只能用于新生的垃圾回收,不能用于老年的垃圾回收。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值