赞
踩
基本概念
学习JVM到一定程度后肯定会接触到safepoint(安全点)的概念,特别是在处理GC问题的时候,这篇文章主要介绍下安全点(safepoint)的概念及如何在JVM环境中开启安全点日志来分析系统的性能.
安全点就是指代码中一些特定的位置,当线程运行到这些位置时它的状态是确定的,这样JVM就可以安全的进行一些操作,比如GC.
这些特定的位置主要有几下几种:
方法返回之前
调用某个方法之后
抛出异常的位置
循环的末尾
为什么把这些位置设置为jvm的安全点呢,主要目的就是避免程序长时间无法进入safepoint,比如JVM在做GC之前要等所有的应用线程进入到安全点后VM线程才能分派GC任务 ,如果有线程一直没有进入到安全点,就会导致GC时JVM停顿时间延长,比如R大之前回复的这个例子,这里面就是写了一个超大的循环导致线程一直没有进入到安全点,GC前停顿了8秒.
safepoint的使用场景垃圾回收(这是最常见的场景)
取消偏向锁(JVM会使用偏向锁来优化锁的获取过程)
Class重定义(比如常见的hotswap和instrumentation)
Code Cache Flushing(JDK1.8在CodeCache满的情况下就可能出现)
线程堆栈转储(jstack命令)
既然这样,线程怎么知道什么时候要进入到saftpoint呢,一般有抢占式和主动式两种,常见的做法就是设置一个状态位,让所有线程去检查这个状态,当检测到saftpoint标志时就停下来,可以看下OpenJdk里对safePoint的描述:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。