java的safepoint介绍

本文讨论了JavaGC在微服务高并发环境中Safepoint调优的四个关键点:关闭定时Safepoint、禁用偏向锁、开启循环内Safepoint和使用debug级日志。这些调整旨在减少性能开销并缩短Safepoint进入时间。
摘要由CSDN通过智能技术生成

可以参考下面wiki,讲的很详细

java GC进入safepoint的时间为什么会这么长? - 知乎

常见的 SafePoint 调优参数以及讲解

1. 建议关闭定时让所有线程进入 Safepoint

对于微服务高并发应用,没必要定时进入 Safepoint,所以关闭 -XX:+UnlockDiagnosticVMOptions -XX:GuaranteedSafepointInterval=0

2. 建议取消偏向锁

在高并发应用中,偏向锁并不能带来性能提升,反而因为偏向锁取消带来了很多没必要的某些线程进入Safepoint 或者 Stop the world。所以建议关闭:-XX:-UseBiasedLocking

3. 建议打开循环内添加 Safepoint 参数

防止大循环 JIT 编译导致内部 Safepoint 被优化省略,导致进入 SafePoint 时间变长:-XX:+UseCountedLoopSafepoints

4. 建议打开 debug 级别的 safepoint 日志(和第五个选一个)

debug 级别虽然看不到每次是哪些线程需要等待进入 Safepoint,但是整体每阶段耗时已经很清楚了。如果是 trace 级别,每次都能看到是那些线程,但是这样每次进入 safepoint 时间就会增加几毫秒。

-Xlog:safepoint=debug:file=safepoint.log:utctime,level,tags:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值