JVM诊断之查看运行参数

问题描述

为了分析和定位一个Java线上系统问题,我们需要查看JVM启动时的一些参数设置,例如:垃圾回收算法、堆大小等等。这些参数可能在启动脚本中明确指明,也可能采用默认值。在系统运行过程中其他人也许动态调整了系统参数。 如何实时查看正在运行的JVM的参数呢?

解决方案

可以采用jcmd来查看正在运行的JVM的参数。jcmd从JDK 7开始引入的一个JVM诊断命令行工具,可以向运行中的JVM发送诊断命令。

查看JVM进程的PID

    $ jcmd -l

      27940 sun.tools.jcmd.JCmd -l

      24684 org.codehaus.plexus.classworlds.launcher.Launcher -Prun

      23839 com.intellij.idea.Main

      23951 org.jetbrains.idea.maven.server.RemoteMavenServer

查看进程24684的参数

    $ jcmd 24684 VM.flags

      24684:

      -XX:InitialHeapSize=98566144 -XX:MaxHeapSize=1547698176 \

      -XX:MaxNewSize=515899392 -XX:MinHeapDeltaBytes=524288 \

      -XX:NewSize=1572864 -XX:OldSize=96993280 \

      -XX:+UseCompressedClassPointers \

      -XX:+UseCompressedOops -XX:+UseParallelGC

堆大小设置,垃圾回收算法等一目了然。


不论是在问题现场还是跳槽面试,面对这些问题,如何快速定位和解决问题,需要你对 Java 虚拟机的实现和优化,有极为深刻的理解。但遗憾的是,很多时候我们都在为了“面试可以造核弹”才去学习 JVM。或者看一些理论书籍和博客,这种针对面试和理论的学习,仍旧无法帮你解决实战场景下的问题。

下面小编给大家,分享小编自己正在阅读的一篇java面试jvm问题集合。

1. 内存模型以及分区,需要详细到每个区放什么。

2. 堆里面的分区:Eden,survival (from+ to),老年代,各自的特点。

3. 对象创建方法,对象的内存分配,对象的访问定位。

4. GC 的两种判定方法:

5. SafePoint 是什么

由于答案图片太多,会使本文字符过长,小编已经为大家准备好了jvm面试问题和答案文档(含PDF版),私信小编【jvm面试】即可免费获取,数量有限先到先得。

6. GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?

7. GC 收集器有哪些?CMS 收集器与 G1 收集器的特点。

8. Minor GC 与 Full GC 分别在什么时候发生?

9. 几种常用的内存调试工具:jmap、jstack、jconsole、jhat

10. 类加载的几个过程:

11.JVM 内存分哪几个区,每个区的作用是什么?

12.如和判断一个对象是否存活?(或者 GC 对象的判定方法)

13.简述 java 垃圾回收机制?

14.java 中垃圾收集的方法有哪些?

15.java 内存模型

16.java 类加载过程?

17. 简述 java 类加载机制?

18. 类加载器双亲委派模型机制?

19.什么是类加载器,类加载器有哪些?

20.简述 java 内存分配与回收策率以及 Minor GC 和 Major GC

由于答案图片太多,会使本文字符过长,小编已经为大家准备好了jvm面试问题和答案文档(含PDF版),私信小编【jvm面试】即可免费获取,数量有限先到先得。

你可能感兴趣的:(JVM诊断之查看运行参数)