服务器JVM等查看

2016-11-02  本文已影响0人  MrBoy2016

常用

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 使用



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
上一篇下一篇

猜你喜欢

热点阅读