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
按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