美文网首页
服务器JVM等查看

服务器JVM等查看

作者: MrBoy2016 | 来源:发表于2016-11-02 13:55 被阅读0次

常用

vmstat 3
pidstat -w 
pidstat -wt 
grep ctxt /proc/$pid/status
jmap -histo:live pid|less
jmap -heap pid
jmap -permstat pid
printf "%x\n" pid
jstack -l pid
jstat -gcutil pid 1000 100

JVM性能调优监控工具
JDK内置工具使用
JAVA线程dump分析
JVM致命错误日志
1 . CPU的监控

#  **vmstat**也可以查看总的上下文切换情况
vmstat 3
# 每个进程的context switching情况
pidstat -w 
# 细分到每个threads
pidstat -wt 
查看proc下的文件方法如下:
# pid=307
# grep ctxt /proc/$pid/status
voluntary_ctxt_switches: 41 #自愿的上下文切换
nonvoluntary_ctxt_switches: 16 #非自愿的上下文切换

cswch/s: 每秒任务主动(自愿的)切换上下文的次数,当某一任务处于阻塞等待时,将主动让出自己的CPU资源。
nvcswch/s: 每秒任务被动(不自愿的)切换上下文的次数,CPU分配给某一任务的时间片已经用完,因此将强迫该进程让出CPU的执行权。

2 . JVM性能查看

  • jinfo:可以输出并修改运行时的java 进程的opts。
  • jps:与unix上的ps类似,用来显示本地的java进程,可以查看本地运行着几个java程序,并显示他们的进程号。
  • jstat:一个极强的监视VM内存工具。可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量。
  • jmap:打印出某个java进程(使用pid)内存内的所有'对象'的情况(如:产生那些对象,及其数量)。
  • jconsole:一个java GUI监视工具,可以以图表化的形式显示各种数据。并可通过远程连接监视远程的服务器VM
# 堆中活动的对象以及大小
jmap -histo:live pid|less
# 查看堆的使用状况信息
jmap -heap pid
# 打印进程的类加载器和类加载器加载的持久代对象信息
jmap -permstat pid
# 查看CPU占用时间最长
printf "%x\n" pid
# 查看jvm线程运行状态,是否有死锁现象等等信息
jstack -l pid
# 1000 ms统计一次gc情况统计 100 次
jstat -gcutil pid 1000 100

3 . Jstat 使用


  • 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情况

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

4 . JVM启动参数

# JVM致命错误日志
-XX:ErrorFile=./hs_err_pid<pid>.log

相关文章

  • 服务器JVM等查看

    常用 JVM性能调优监控工具JDK内置工具使用JAVA线程dump分析JVM致命错误日志1 . CPU的监控 cs...

  • 工具

    查看当前运行的jvm线程号等信息jps,增强版jcmd查看jvm的gc实时监控统计信息jstat查看jvm的堆内存...

  • JVM调优常用命令

    jps jps可以用来查看java进程的pid 进程名等相关信息 jinfo jinfo pid是用来查看JVM参...

  • JVM相关信息查看

    1. jps,查看jvm实例 2. jstat,jvm统计信息,包含内存信息及GC信息 3. jmap,查看JVM...

  • JVM学习笔记与调优实战(六):Tomcat调优实例与性能测试工

    标签: JVM 1、典型tomcat优化配置: 解析: -Xms的内存值如何选择:根据实际业务来定,先查看服务器上...

  • JVM内存分析

    JVM常用命令 jps 查看所有的java进程ID jinfo 实时查看和调整JVM配置参数查看jinfo -fl...

  • Java GC机制

    Java GC机制是JVM中一个最重要的部分,了解GC机制也对了解JVM中内存分布,日志查看等原理有所了解 存储划...

  • JVM内存分配理解

    JVM进程内存疑惑 一段时间,老是收到服务器内存不够用的告警(运维设置的可用内存低于90%即告警),登录服务器查看...

  • 解决java调试工具无法连接jvm

    1.现象在Linux服务器执行jstack pid查看java堆栈信息时提示错误,无法连接上jvm调试工具 2.原...

  • JVM-查看默认参数

    查看JVM 默认参数命令: java -XX:+PrintCommandLineFlags -version 查看...

网友评论

      本文标题:服务器JVM等查看

      本文链接:https://www.haomeiwen.com/subject/laimuttx.html