-
JVM
类的加载(过程,以及每个过程在干什么):
装载、验证、准备、解析、初始化、使用、卸载
1.装载:
a>类的的全限定名来获取定义此类的二进制字节流
b>将常量池转变成运行时常量池
c>在内存中生成类对象,作为方法区各数据的访问入口。
2.验证:确保class文件的字节流中包含的信息,符合当前虚拟机的要求,不会造成危害
3.准备:类变量分配内存并设置初始值的阶段,注意 public static int a= 123,在准备阶段,a的值是0,赋值成123是在初始化的时候做的
4.解析:将常量池的符号引用转化为直接引用
5.初始化:执行类构造器<client>方法
JVM 调优:
核心思想就是减少FULL GC 的次数;
导致full GC的原因:年老代(Tenured)被写满;持久代Pemanet Generation空间不足;System.gc()被显示调用,手动调用
系统崩溃前的一些现象:
- 每次垃圾回收的时间越来越长,由之前的10ms延长到50ms左右,FullGC的时间也有之前的0.5s延长到4、5s
- FullGC的次数越来越多,最频繁时隔不到1分钟就进行一次FullGC
- 年老代的内存越来越大并且每次FullGC后年老代没有内存被释放
下一步就需要:分析内存快照dump,可以配置 -XX:+HeapDumpOnOutOfMemoryError,OOM 时 自动生成HeapDump的转储文件,方便问题排查。
JVM设置技巧:
XMX和XMS设置一样大,可以减轻伸缩堆大小带来的压力;
–Xmx –Xms –Xmn -XX:SurvivorRatio -XX:MaxTenuringThreshold
VisualVM排查死锁: 进入tomcat/bin 双击打开jvisulVM.exe 连接本地后,选择线程,获取线程dump,查看是否有死锁被发现