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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值