Java面试经常会考察JVM面试题,下面给家总结了一份非常全面的JVM调优面试题及答案详解,希望对大家有所帮助。
什么是JVM调优?
JVM调优是通过调整JVM参数,以及优化应用程序代码,从而优化JVM的性能和吞吐量的过程。
为什么需要进行JVM调优?
JVM调优是重要的,因为JVM是Java应用程序的核心运行时环境,JVM的性能和吞吐量直接影响应用程序的性能和吞吐量。
什么场景需要JVM调优?
- OutOfMemoryError,内存不足;
- 内存泄露;
- 线程死锁;
- Java进程消耗CPU过高;
如何检测JVM的性能问题?
可以使用JVM工具,比如:jps、jstat、jmap、Jconsole、Jprofiler、VisualVM等工具,来检测JVM的性能问题。
JVM常见的调优工具?
JVM调优工具,常见的有:
- Jconsole : jdk自带,功能简单,对垃圾回收算法有很详细的跟踪;
- JProfiler:商业软件,功能强大;
- VisualVM:JDK自带,与JProfiler类似;
- MAT:MAT(Memory Analyzer Tool),一个基于Eclipse的内存分析工具;
这些工具可以提供有关堆使用情况、GC性能、线程使用情况等的统计数据,从而可以确定JVM性能瓶颈所在。
如何优化JVM的性能?
可以采用以下策略来优化JVM的性能:
JVM性能调优步骤,主要分为4个步骤:
1.监控GC的状态
使用各种JVM工具,查看当前日志,并且分析当前堆内存快照和gc日志,根据实际的各区域内存划分和GC执行时间,觉得是否进行优化。
举一个例子: 系统崩溃前的一些现象:
- 每次垃圾回收的时间越来越长,FullGC的时间也有之前的0.5s延长到4、5s;
- FullGC的次数越来越多,最频繁时隔不到1分钟就进行一次FullGC;
2.调整JVM参数
比如:堆大小、GC策略等。
3.分析dump文件
比如:生成堆的dump文件,hprof文件,然后利用工具:Visual VM、Mat等工具来分析。
分析程序的源代码,找出嫌疑对象数量过多的原因。
4.不断的分析和调整
通过不断的试验和试错,分析并找到最合适的参数,如果找到了最合适的参数。
JVM的堆内存分配原理是什么?如何调整堆大小?
JVM的堆内存分配是在JVM启动时由:-Xms和-Xmx参数决定的。
-Xms参数设置JVM堆的最小值;
-Xmx参数设置JVM堆的最大值;
为了防止垃圾收集器在最小、最大之间收缩堆而产生额外的时间,通常把最大、最小设置为相同的值。
什么是类加载器?如何优化类加载器性能?
类加载器负责将Java类加载到JVM中,JVM中存在三种类加载器:启动类加载器、扩展类加载器和应用程序类加载器。
可以通过以下策略来优化类加载器性能:
- 避免创建过多的类加载器对象;
- 将常用的类放在启动类加载器或扩展类加载器中,以避免重复加载;
- 避免使用动;
什么是GC?如何优化GC性能?
GC,就是垃圾回收的简称,优化GC性能,可以提高JVM的性能和吞吐量
可以通过以下策略来优化GC性能:
- 选择适当的GC策略,比如:Serial GC、Parallel GC、CMS GC、以及G1 GC等;
- 调整GC参数,如堆大小、GC线程数等;
- 避免创建过多的临时对象;
- 避免在GC期间进行I/O操作等操作;
以上就是常见的JVM调优面试题及答案,更多的Java面试题及答案,请查看:1000+Java面试题及答案详解。
mikechen睿哥
mikechen睿哥,十余年BAT架构经验,资深技术专家,就职于阿里、淘宝、百度等一线互联网大厂。
关注「mikechen」公众号,获取更多技术干货!
后台回复【面试】即可获取《史上最全阿里Java面试题总结》,后台回复【架构】,即可获取《阿里架构师进阶专题全部合集》