java性能调优概览

java性能优化分层:
应用层:理解代码逻辑,通过java线程栈定位有问题代码行;
数据库层:分析sql,定位死锁;
框架层:懂源代码,理解框架机制
jvm层:了解gc类型和工作机制,了解jvm参数


使用性能诊断工具
os层面和java应用层面


os诊断:cpu,memory,io
cpu诊断:
关注点:平均负载,cpu使用率,上下文切换次数
命令:top
top #大概两个展示区:统计信息区和进程信息区
统计信息区:整体信息,cpu信息,内存信息;关注点:load average:1min,5min,15min到现在的平均值
进程信息区:pid进程id,uid用户id,user用户名,tty终端名或?,pr优先级,cpu占用百分比,mem物理内存百分比,virt虚拟内存,time使用线程时间,s状态,command命令
top -H -p <pid> #-p指定pid,-H展示所有线程
一般load average低于cpu*0.7算正常,查看有多少个cpu(linux下):cat /proc/cpuinfo | grep "cpu cores" | uniq


命令:vmstat
查看cpu上下文切换次数,也就是执行任务切换次数


java应用层诊断:
命令:jstack
配合top使用,通过top -H -p <pid>定位java进程和线程,使用jstack -l pid 导出线程栈。线程栈是瞬态的,5s导出一次,导出三次比较。
top定位的java线程pid转为16进制,可得到java线程栈的nid,其中nid是jstack命令中表示线程的id
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值