JVM 部分命令

原创 2015年11月18日 20:25:16

JVM 部分命令

jstat

  1. 这是一个比较实用的一个命令,可以观察到classloader,compiler,gc相关信息。可以时时监控资源和性能
  2. 命令格式
    -class:统计class loader行为信息
    -compile:统计编译行为信息
    -gc:统计jdk gc时heap信息
    -gccapacity:统计不同的generations(不知道怎么翻译好,包括新生区,老年区,permanent区)相应的heap容量情况
    -gccause:统计gc的情况,(同-gcutil)和引起gc的事件
    -gcnew:统计gc时,新生代的情况
    -gcnewcapacity:统计gc时,新生代heap容量
    -gcold:统计gc时,老年区的情况
    -gcoldcapacity:统计gc时,老年区heap容量
    -gcpermcapacity:统计gc时,permanent区heap容量
    -gcutil:统计gc时,heap情况

  3. 输出参数内容
    S0 — Heap上的 Survivor space 0 区已使用空间的百分比
    S0C:S0当前容量的大小
    S0U:S0已经使用的大小
    S1 — Heap上的 Survivor space 1 区已使用空间的百分比
    S1C:S1当前容量的大小
    S1U:S1已经使用的大小
    E — Heap上的 Eden space 区已使用空间的百分比
    EC:Eden space当前容量的大小
    EU:Eden space已经使用的大小
    O — Heap上的 Old space 区已使用空间的百分比
    OC:Old space当前容量的大小
    OU:Old space已经使用的大小
    P — Perm space 区已使用空间的百分比
    OC:Perm space当前容量的大小
    OU:Perm space已经使用的大小
    YGC — 从应用程序启动到采样时发生 Young GC 的次数
    YGCT– 从应用程序启动到采样时 Young GC 所用的时间(单位秒)
    FGC — 从应用程序启动到采样时发生 Full GC 的次数
    FGCT– 从应用程序启动到采样时 Full GC 所用的时间(单位秒)
    GCT — 从应用程序启动到采样时用于垃圾回收的总时间(单位秒),它的值等于YGC+FGC

jmap

  1. 得到运行java程序的内存分配的详细情况。例如实例个数,大小等
  2. 命令行格式
    jmap [ option ] pid
    jmap [ option ] executable core
    jmap [ option ] [server-id@]remote-hostname-or-IP
    -dump:[live,]format=b,file= 使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件.
    -finalizerinfo 打印正等候回收的对象的信息.
    -heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况.
    -histo[:live] 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量.
    -permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量. 另外,内部String的数量和占用内存数也会打印出来.
    -F 强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效.
    -h | -help 打印辅助信息
    -J 传递参数给jmap启动的jvm.
  3. 常用实例
    jmap -histo pid(查看实例)
    jmap -dump:format=b,file=heap.bin pid(导出内存,据说对性能有影响,小心使用)

jstack

  1. jstack能得到运行java程序的java stack和native stack的信息。可以轻松得知当前线程的运行情况。如下图所示
  2. 命令格式
    jstack [ option ] pid
    jstack [ option ] executable core
    jstack [ option ] [server-id@]remote-hostname-or-IP
    最常用的还是jstack pid
  3. 几种状态
    死锁,Deadlock(重点关注)
    等待资源,Waiting on condition(重点关注)
    • 等待获取监视器,Waiting on monitor entry(重点关注)
    阻塞,Blocked(重点关注)
    • 执行中,Runnable
    • 暂停,Suspended
    • 对象等待中,Object.wait() 或 TIMED_WAITING
    • 停止,Parked
    下面有详细的例子讲这种分析,大家参考原著
    http://www.cnblogs.com/zhengyun_ustc/archive/2013/01/06/dumpanalysis.html

如何合理设置hadoop相关组件的jvm Xmx

1.这个问题不是很简单么?直接设置不久好了,java -Xmx2000m像这样不就好了。No,我说的不仅仅是这个问题,比如,你看到/usr/local/bigdata/jdk/bin/java -Xm...
  • leochenx
  • leochenx
  • 2015年04月23日 12:18
  • 1914

Jvm(jdk8)源码分析1-java命令启动流程详解

1.概述 现在大多数互联网公司都是使用java技术体系搭建自己的系统,所以对java开发工程师以及java系统架构师的需求非常的多,虽然普遍的要求都是需要熟悉各种java开发框架(如目前比较流行ssi...
  • wanweiaiaqiang
  • wanweiaiaqiang
  • 2016年07月02日 11:11
  • 6485

简述Java命令行参数、JVM、打包Java程序、JAR文件

关于命令行参数 public class HelloWorld { public static void main(String[ ] args) {//接收命令行参数 for(int i=...
  • qq_26282959
  • qq_26282959
  • 2016年07月21日 15:15
  • 1764

jvm常用命令工具

  • 2014年03月24日 09:42
  • 291KB
  • 下载

JAVA命令大全-JVM设置.rar

  • 2009年11月26日 01:45
  • 24KB
  • 下载

jvm的部分读书笔记

在C里面我们想执行一段自己编写的机器指令的方法大概如下: typedef void(*FUNC)(int); char* str = "your code"; FUNC f = (FUNC)str;...
  • qq_33621802
  • qq_33621802
  • 2017年12月24日 18:42
  • 9

JVM内存中各部分存放的内容

虚拟机内存中主要有程序计数器、虚拟机栈、本地方法栈、堆和方法区。 程序计数器和虚拟机栈都是线程“私有”的内存。 程序计数器是一块比较下的内存空间,主要村放代码执行的位置。分支、循环、跳转、...
  • sun337939896
  • sun337939896
  • 2018年01月18日 09:53
  • 1

深入理解java虚拟机:JVM高级特性与最佳实践第一部分走近Java第1章走近Java

世界上并没有完美的程序,但我们并不因此而沮丧,因为写程序本来就是一个不断追求完美的过程。 1.1 概述 Java不仅仅是一门编程语言,还是一个由一系列计算机软件和规范形成的技术体系,这个技术体系提...
  • ak47java
  • ak47java
  • 2017年12月04日 14:09
  • 79

JVM的基本结构及其各部分详解(一)

1 java虚拟机的基本结构如图: 1)类加载子系统负责从文件系统或者网络中加载Class信息,加载的类信息存放于一块称为方法区的内存空间。除了类的信息外,方法区中可能还会存放运行时常量池信息,...
  • xiaobao5214
  • xiaobao5214
  • 2017年05月10日 18:40
  • 117

JVM 内存空间分为几部分

内存空间分几部分:代码段、数据段,栈,堆 (收集整理) 1.函数代码存放在代码段。声明的类如果从未使用,则在编译时,会优化掉,其成员函数不占代码段空间。 全局变量或静态变量,放在数据段, 局部变...
  • u014421556
  • u014421556
  • 2016年09月01日 10:33
  • 2957
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JVM 部分命令
举报原因:
原因补充:

(最多只允许输入30个字)