java tuning

top   cpu分析

按shift+H 可按线程查看

查出us高的线程id ,用kill -3 javapid 或jstack方式 dump出线程信息,将线程id转为十六进制
jstack pid|grep nid=16进制pid


jstack -l javapid dump出java线程信息

iostat 或iostat -x xvda  当iowait过高时,就是io有问题了

网络
sar -n FULL 1 2 //1秒为频率,总共二次

内存  vmstat 或sar -r

jssta jmap


调优常用命令

jps

jinfo pid

jstack
jmap
jstat
jstat

RUNNABLE(正在运行的,消耗cpu)  TIMED_WAITING(等待被分配到cpu运行的,现在不消耗cpu) BLOCKED(被阻塞,在阻塞解除前不能被分配cpu执行,现在不消耗cpu)


-Xmn
new Generation
Eden space survior space s0 s1

-XX:SurvivorRation=8  设置Eden 与Survior 比例
old generation = -Xmx-xmn

方法栈-xss

gc 日志
-verbose:gc -XXPrintGCDetails
-verbose:gc控制台
-XX:+printGC 简要信息
-XX:printGCDetial 详细信息
-XX:+printGCTimeStamps gc时间信息及gc造成的应用暂停时间
-Xloggc:gc.log 指定输出输出到gc.log

导出jvm内存情况
jmap -dump:format=b,file=fileName pid


gstat -gcutil pid interval
so ,s1 为Suvivor 空间使用率
E eden空间使用率
O old 空间使用率
YGC  minor gc 次数
YGCt minor gc 消耗时间  单位s
FGC
FGCT
GCT :minor +full gc 时间

mpstat -P ALL//每个 处理器情况

kill -c pid 线程相关信息输出到控制器台
jstack pid  waiting for monitor entry 等待锁的状态
Object.wait 表线程处在对象的wait ,等待其它线程唤醒
TIME_WAINTING (on object monitor)已经取得object monitor,就差cpu就可以运行了

jstat -gcutil pid  1000  //一秒一次
[@zjm_12_196 ~]$ jps -mlv //查看启动参数信息

文件io
pidstat -d -t -p[pid]...
iostat
iostat -x xvda

http://www.ibm.com/developerworks/cn/aix/library/es-Javaperf/es-Javaperf1.html

查看端口
netstat -an | grep 9099 | awk '{print $6}' | sort | uniq -c | sort -rn
http://blog.bluedavy.com/?p=290
https://gist.github.com/1081908
http://blog.scoutapp.com/articles/2009/07/31/understanding-load-averages

dump 出java内存 jmap -dump:format=b,file=dump.bin pid

你可能感兴趣的:(java)