-
jinfo:可以输出并修改运行时的java 进程的opts。
-
jps:
与unix上的ps类似,用来显示本地的java进程,可以查看本地运行着几个java程序,并显示他们的进程号。
-
jstat:
一个极强的监视VM内存工具。可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量。
-
jmap:
打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。
-
jconsole:
一个java GUI监视工具,可以以图表化的形式显示各种数据。并可通过远程连接监视远程的服务器VM。
-
-
接
下来是对这些工具的详细介绍:
-
-
从最简单的
jstat工具开始:我想很多人都是用过unix系统里的ps命令,这个命令主要是用来显示当前系统的进程情况,有哪些进程,及其id。jps 也是一
样,它的作用是显示当前系统的java进程情况,及其id号。我们可以通过它来查看我们到底启动了几个java进程(因为每一个java程序都会独占一个
java虚拟机实例),和他们的进程号(为下面几个程序做准备),并可通过opt来查看这些进程的详细启动参数。
-
使
用方法:在当前命令行下打 jps(需要JAVA_HOME,没有的话,到改程序的目录下打)
-
-
接
下来是jstat,我之所以这次调优Liferay portal是因为,liferay在默认的情况下,并发用户一多就会产生
perm out of momery异常。虽然很开就解决了,但发现对VM内存使用量监控的重要性。通过google,很快的发现了jstat这个工
具。
-
jstat工具特别强大,有众多的可选项,详细查看堆内各个部分的使用量,以及加载类的数
量。使用时,需加上查看进程的进程id,和所选参数。以下详细介绍各个参数的意义。
-
jstat -class
pid:显示加载
class
的
数量,及所占空间等信息。
-
jstat -compiler pid:显示VM实时
编译的数量等信息。
-
jstat -gc pid:可以显示gc的信息,查看gc的次数,及时间。
其中最后五项,分别是young gc的次数,young gc的时间,full gc的次数,full gc的时间,gc的总时间。
-
jstat -gccapacity:
可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小,如:PGCMN显示的是最小perm的内存使用量,PGCMX显示的是
perm的内存最大使用量,PGC是当前新生成的perm内存占用量,PC是但前perm内存占用量。其他的可以根据这个类推, OC是old内纯的占用
量。
-
jstat -gcnew pid:new
对
象的信息。
-
jstat -gcnewcapacity pid:new
对象的信息及其占用量。
-
jstat -gcold pid:old
对象的信息。
-
jstat -gcoldcapacity pid:old对象的信息及其占用
量。
-
jstat -gcpermcapacity pid: perm对象的信息及其占用
量。
-
jstat -util pid:统计gc信息统计。
-
jstat -printcompilation pid:
当前VM执行的信息。
-
除了以上一个参数外,还可以同时加上 两个数字,
如:jstat -printcompilation 3024
250
6
是
每
250
毫秒打印一次,一共打印
6
次,还可以加上-h3每三行显示一下标题。
-
-
jmap
是一个可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本。使用方法 jmap -histo pid。如果连用
SHELL jmap -histo pid>a.log可以将其保存到文本中去,在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对
象。jmap -dump:format=b,file=String 3024
可
以将
3024
进程的内存heap输出出来到String文件
里。
-
-
jinfo:的用处比
较简单,就是能输出并修改运行时的java进程的运行参数。用法是jinfo -opt pid 如:查看2788
的
MaxPerm大小可以用 jinfo -flag MaxPermSize
2788
。
-
-
jconsole
是一个用java写的GUI程序,用来监控VM,并可监控远程的VM,非常易用,而且功能非常强。由于是GUI程序,这里就不详细介绍了,不会的地方可以
参考SUN的官方文档。
-
使用方法:命令行里打 jconsole,选则进程就可以了。
-
-
以
下是这些工具的SUN官方说明:
-
jps:http:
-
jstat:http:
-
jmap:http:
-
jconsole:http:
-
-
附
加:windows查看进程号,由于任务管理器默认的情况下是不显示进程id号的,所以可以通过如下方法加上。ctrl+alt+del打开任务管理器,
选择‘进程’选项卡,点‘查看’->'选择列'
->加上
'PID'
,就可以了。
Jstat介绍:
用以判断JVM是否存在内存问题呢?如何判断JVM垃圾回收是否正常?一般的top指令基本上满足不了这样的需求,因为它主要监控的是总体的系统资源,很难定位到java应用程序。
Jstat是JDK自带的一个轻量级小工具。全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控。可见,Jstat是轻量级的、专门针对JVM的工具,非常适用。由于JVM内存设置较大,图中百分比变化不太明显
一个极强的监视VM内存工具。可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量。
jstat工具特别强大,有众多的可选项,详细查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。
执行:cd $JAVA_HOME/bin中执行jstat,注意jstat后一定要跟参数。
分享到:
相关推荐
### JVM内存监控工具详解 #### 引言 Java Virtual Machine (JVM) 是运行 Java 应用程序的核心组件,其性能直接影响应用的响应速度和稳定性。JVM 的内存管理是性能优化的关键,尤其是在高并发环境下,合理的内存...
原文链接:https://blog.csdn.net/m0_37814112/article/details/119028528 说明:Kubernetes集群之微服务JVM内存监控,prometheus服务yaml文件
jvm内存监控及调优方法,详细讲解jvm的原理以及常用调优手段
【Java JVM内存监控工具详解】 Java JVM内存监控是优化Java应用程序性能的关键环节,而VisualVM作为一款集成多种JDK命令行工具的可视化平台,提供了强大的分析功能。它包含的工具如jps、jstat、jmap、jinfo、jstack...
`vmmap`工具是Mac OS X系统中一个强大的内存分析工具,它可以用来深入观察JVM内存的分配和使用情况。本文将详细讲解如何利用`vmmap`监控JVM,理解其核心概念,以及分析JVM线程。 首先,`vmmap`是Apple提供的命令行...
说明:grafana监控jvm内存模板,本人根据官方模板修改而来,做了一些优化。
JVM 内存管理之道 JVM垃圾回收机制 JVM GC组合 JVM 内存监控工具
只需下载JProfiler11的安装包,并按照指引将其导入Idea,即可轻松开启内存监控之旅。 在导入JProfiler11插件后,我们可以通过Idea的菜单栏或者快捷键启动该工具。一旦启动,JProfiler11将连接到当前运行的JVM实例,...
### JVM内存空间分配详解 #### 一、JVM内存模型概览 JVM(Java虚拟机)内存模型主要由以下几个部分组成:程序计数器、Java虚拟机栈、本地方法栈、Java堆以及方法区(在JDK 8之后称为元空间)。下面将对这几个部分...
在这份由Sun Microsystems公司出版的《JVM内存管理白皮书》中,我们可以找到关于Java虚拟机(JVM)内存管理的详细介绍和深入分析。这份文档对于想要深入了解JVM工作原理的读者来说是一份宝贵的学习资料。在这份...
本文将深入探讨如何在Java中获取JVM内存大小,包括堆内存的总量、最大值以及剩余空间,并解析给定代码片段中的关键概念。 ### JVM内存模型 在讨论如何获取JVM内存大小之前,首先需要理解JVM的内存布局。JVM内存...
Java虚拟机(JVM)是Java程序运行的基础,它负责管理程序的内存、执行字节码以及处理垃圾收集。在开发和优化Java应用程序时,理解...在实际工作中,定期监控和分析JVM内存日志是确保应用稳定性和高效运行的关键步骤。
5. **使用插件**:安装并配置好插件后,按照插件的使用说明,在Eclipse中激活内存监控功能,使其在状态栏显示JVM内存使用情况。 对于"源码"标签,这可能意味着实现这个功能可能涉及查看和理解Eclipse或相关插件的源...
《VisualGC:深入理解JVM内存监控利器》 在Java开发过程中,对于应用程序的性能优化,内存管理是一项至关重要的任务。VisualGC作为JVM(Java虚拟机)内存监控的插件,为开发者提供了直观且详尽的内存使用情况,帮助...
### Tomcat JVM内存设置方法详解 #### 一、前言 Tomcat作为一款广泛使用的Java应用服务器,其性能优化一直是开发者关注的重点之一。而在性能优化的过程中,合理设置JVM(Java Virtual Machine)内存是非常关键的一...
1. **JVM内存结构** JVM内存主要分为以下几个区域: - **方法区(Method Area)**:这是所有线程共享的区域,存储类信息、常量、静态变量、即时编译后的代码等。在Java 8以前,这部分也被称为永久代(Permanent ...
本教程将涵盖JVM内存模型、内存分配以及优化策略。 一、JVM内存模型 1. 堆内存:堆是所有线程共享的一块内存区域,主要用于存储对象实例。Java中的动态内存分配主要在堆上进行,垃圾收集器也会对堆进行管理,进行...
### JVM内存结构详解 #### 一、概述 Java虚拟机(JVM)作为Java程序的运行环境,其核心组件之一便是内存管理系统。理解JVM的内存布局对于开发高性能的应用程序至关重要。本文将详细介绍JVM内存结构及其各个组成部分...
说明:kubernetes集群监控jvm内存监控模板
JVM内存管理是Java平台的一个重要特性,其内存空间的分配和回收机制对Java应用程序的性能和稳定性有着至关重要的影响。 首先,JVM内存管理涉及的内存空间主要分为方法区(Method Area)、堆(Heap)、本地方法栈...