获取正在运行的JVM的参数

问题描述 投票:73回答:10

有没有办法获取正在运行的JVM的参数?是否有像jstat这样的命令行工具,它将JVM的pid作为输入并返回其起始参数?我对启动JVM时给出的-Xmx和-Xms值特别感兴趣。谢谢。

编辑:澄清我的约束。我们要检查的JVM正在生产服务器上运行。这就是为什么,我们更喜欢最小的破坏。我们可以使用jstat监视JVM,因此我们希望有一个类似的简单解决方案来访问参数。

编辑:我们还尝试使用jvisualvm获取参数。但是为了连接到远程jvm,我们需要运行jstatd并修改JVM的安全设置,我们发现它在生产服务器上非常具有破坏性和风险。

java jvm
10个回答
120
投票

你可以使用jps之类的

jps -lvm

打印像

4050 com.intellij.idea.Main -Xms128m -Xmx512m -XX:MaxPermSize=250m -ea -Xbootclasspath/a:../lib/boot.jar -Djb.restart.code=88
4667 sun.tools.jps.Jps -lvm -Dapplication.home=/opt/java/jdk1.6.0_22 -Xms8m

0
投票

您可以使用JConsole命令(或任何其他JMX客户端)来访问该信息。


21
投票

我正在添加这个新的答案,因为根据JDK8 documentation jcmd现在建议的方法。

建议使用最新的实用程序jcmd代替以前的jstack,jinfo和jmap实用程序,以增强诊断并降低性能开销。

以下是获取所需属性/标志的命令。

jcmd pid VM.system_properties
jcmd pid VM.flags

我们需要pid,为此使用jcmd -l,如下所示

username@users-Air:~/javacode$ jcmd -l 
11441 Test 
6294 Test 
29197 jdk.jcmd/sun.tools.jcmd.JCmd -l 

现在是时候使用这些pid获取你想要的属性/标志了

命令:jcmd 11441 VM.system_properties

11441:
#Tue Oct 17 12:44:50 IST 2017
gopherProxySet=false
awt.toolkit=sun.lwawt.macosx.LWCToolkit
file.encoding.pkg=sun.io
java.specification.version=9
sun.cpu.isalist=
sun.jnu.encoding=UTF-8
java.class.path=.
java.vm.vendor=Oracle Corporation
sun.arch.data.model=64
java.vendor.url=http\://java.oracle.com/
user.timezone=Asia/Kolkata
java.vm.specification.version=9
os.name=Mac OS X
sun.java.launcher=SUN_STANDARD
user.country=US
sun.boot.library.path=/Library/Java/JavaVirtualMachines/jdk-9.jdk/Contents/Home/lib
sun.java.command=Test
http.nonProxyHosts=local|*.local|169.254/16|*.169.254/16
jdk.debug=release
sun.cpu.endian=little
user.home=/Users/XXXX
user.language=en
java.specification.vendor=Oracle Corporation
java.home=/Library/Java/JavaVirtualMachines/jdk-9.jdk/Contents/Home
file.separator=/
java.vm.compressedOopsMode=Zero based
line.separator=\n
java.specification.name=Java Platform API Specification
java.vm.specification.vendor=Oracle Corporation
java.awt.graphicsenv=sun.awt.CGraphicsEnvironment
sun.management.compiler=HotSpot 64-Bit Tiered Compilers
ftp.nonProxyHosts=local|*.local|169.254/16|*.169.254/16
java.runtime.version=9+181
user.name=XXXX
path.separator=\:
os.version=10.12.6
java.runtime.name=Java(TM) SE Runtime Environment
file.encoding=UTF-8
java.vm.name=Java HotSpot(TM) 64-Bit Server VM
java.vendor.url.bug=http\://bugreport.java.com/bugreport/
java.io.tmpdir=/var/folders/dm/gd6lc90d0hg220lzw_m7krr00000gn/T/
java.version=9
user.dir=/Users/XXXX/javacode
os.arch=x86_64
java.vm.specification.name=Java Virtual Machine Specification
java.awt.printerjob=sun.lwawt.macosx.CPrinterJob
sun.os.patch.level=unknown
MyParam=2
java.library.path=/Users/XXXX/Library/Java/Extensions\:/Library/Java/Extensions\:/Network/Library/Java/Extensions\:/System/Library/Java/Extensions\:/usr/lib/java\:.
java.vm.info=mixed mode
java.vendor=Oracle Corporation
java.vm.version=9+181
sun.io.unicode.encoding=UnicodeBig
java.class.version=53.0
socksNonProxyHosts=local|*.local|169.254/16|*.169.254/16

命令:jcmd 11441 VM.flags输出:

11441:
-XX:CICompilerCount=3 -XX:ConcGCThreads=1 -XX:G1ConcRefinementThreads=4 -XX:G1HeapRegionSize=1048576 -XX:InitialHeapSize=67108864 -XX:MarkStackSize=4194304 -XX:MaxHeapSize=1073741824 -XX:MaxNewSize=643825664 -XX:MinHeapDeltaBytes=1048576 -XX:NonNMethodCodeHeapSize=5830092 -XX:NonProfiledCodeHeapSize=122914074 -XX:ProfiledCodeHeapSize=122914074 -XX:ReservedCodeCacheSize=251658240 -XX:+SegmentedCodeCache -XX:-UseAOT -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseFastUnorderedTimeStamps -XX:+UseG1GC 

有关jcmd的更多使用说明,请参阅my blog post


20
投票

或者,您可以使用jinfo

jinfo -flags <vmid> 
jinfo -sysprops <vmid>

13
投票

如果您可以在java中执行此操作,请尝试:

RuntimeMXBean

ManagementFactory

例:

RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean();
List<String> jvmArgs = runtimeMXBean.getInputArguments();
for (String arg : jvmArgs) {
    System.out.println(arg);
}

13
投票

在Linux上:

java -XX:+PrintFlagsFinal -version | grep -iE 'HeapSize|PermSize|ThreadStackSize'

在Mac OSX上:

java -XX:+PrintFlagsFinal -version | grep -iE 'heapsize|permsize|threadstacksize'

在Windows上:

C:\>java -XX:+PrintFlagsFinal -version | findstr /i "HeapSize PermSize ThreadStackSize"

资料来源:https://www.mkyong.com/java/find-out-your-java-heap-memory-size/


8
投票

JConsole可以做到这一点。您还可以使用功能强大的jvisualVM工具,该工具自1.6.0.8开始也包含在JDK中。


1
投票

此技术适用于任何运行本地或远程的Java应用程序。

  1. 启动你的java应用程序。
  2. 运行JDK中的JVisualVM(例如C:\ Program Files \ Java \ jdk1.8.0_05 \ bin \ jvisualvm.exe)。
  3. 当这个有用的工具开始时,查看“Local”树节点下运行的java应用程序列表。
  4. 双击[您的应用程序](pid [n])。
  5. 在右侧,应用程序的选项卡中将有检查内容。在Overview选项卡的中间,您将看到应用程序的JVM参数。

自JDK 6 Update 7以来,jvisualvm可以在任何JDK中找到.jvisualvm上的视频教程是here.


1
投票

Windows 10或Windows Server 2016在其标准任务管理器中提供此类信息。一种罕见的生产情况,但如果目标JVM在Windows上运行,查看其参数的最简单方法是按Ctrl + Alt + Delete,选择“进程”选项卡并添加“命令行”列(通过单击鼠标右键)任何现有的列标题)。


1
投票

如果您对获取正在运行的java进程的JVM参数感兴趣,那么只需执行kill -3 java-pid。您将获得一个核心转储文件,您可以在其中找到启动Java应用程序时使用的jvm参数。

© www.soinside.com 2019 - 2024. All rights reserved.