记线上问题排查过程

背景:最近消息对队列的数据堆积很厉害,经查询发现每次堆积时gc中能看到程序停

2019-11-21T00:32:19.714+0800: 20943.373: Total time for which application threads were stopped: 3.3090540 seconds, Stopping threads took: 3.2776961 seconds

1、查看什么原因导致的停顿,启动参数加入

-XX:+PrintSafepointStatistics
-XX:PrintSafepointStatisticsCount=1
-XX:+UnlockDiagnosticVMOptions
-XX:+LogVMOutput
-XX:LogFile=vm.log

然后重新启动程序,观察生成的gc.log和vm.log,发现里面很多

391.750: RevokeBias                       [      59          1              1    ]      [  1925     0  1925     0     0    ]  1   
         vmop                    [threads: total initially_running wait_to_block]    [time: spin block sync cleanup vmop] page_trap_count

2、取消偏向锁,启动参数中加入

-XX:-UseBiasedLocking

发现问题还是存在,只是少了很多。现在大部分GC收集时,如下所示

2907.359: GenCollectForAllocation          [      59          1              2    ]      [  2050  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值