jvm优化与jdk监控工具的使用

在这里插入图片描述

为什么优化JVM

  • 生产环境和本地开发环境大相径庭:日志不输出,CPU负载突然升高,分配线程数量

JVM的运行参数

三种参数类型

  • 标准参数:-help,-version,一般不会改变,所有的JVM必须实现(永远健康)
  • -X参数:非标准参数 -Xint,-Xcomp,默认JVM实现这些参数,但不保证所有jvm兼容,也不保证向后兼容
  • -XX参数:非稳定参数(使用率较高),-XX:newSize,各个jvm会有不同,将来有可能会取消

标准参数

  • 通过 -Dname设置环境标识,根据不同环境选择不同配置
    在这里插入图片描述
  • 通过-server(64)或-client(32,可选择)设置jvm的运行参数,分为两个模式(垃圾回收器等组件会有区别)

在这里插入图片描述

-X非标准参数

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

-XX非标准参数

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

JVM 内存调优

在这里插入图片描述
为什么要废除永久代

  • 为了融合JRockit虚拟机
  • 不断热部署,永久区越来越多,而GC也不会管理这一区域。

jstat

在这里插入图片描述
class加载统计
在这里插入图片描述
编译统计
在这里插入图片描述
垃圾回收统计
在这里插入图片描述

jmap

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

JVM调优实战

JVM调优(原理)步骤

调优目的

  • 吞吐量:用户代码时间 / (用户代码执行时间 + 垃圾回收时间)
  • 响应时间:STW越短,响应时间越少

什么是调优

  • 根据需求进行JVM规划和预调优
  • 优化运行JVM运行环境(慢、卡顿)
  • 解决JVM运行过程中出现的各种问题

如何调优

  • 系统CPU经常100%
    CPU100%那么一定有线程占用系统资源
    1.找出哪个进程CPU占用高(top)
    2.找出该进程哪个线程CPU高(top -Hp pid)
    3.把线程号转16进制(printf %x tid)
    4.导出该线程的堆栈信息(jstack pid)
    重点关注:WAITING/BLOCKED
    找到线程中waiting on 的都有哪些,找到是哪个线程持有这把锁

  • 系统内存占比高
    1.导出堆内存(jmap)
    2.分析(jhat jvisualvm mat jprofiler …)

常用命令

  • jstack pid| grep 十六进制 -A20 命令,如 jstack 24314 | grep 5f0f -A20 打印20行线程的堆栈信息。
  • jstat -gc pid 查看进程GC信息
  • jmap -histo pid| head -20 查看对象占用内存情况
  • jmap -dump:format=b,file=xxx pid / jmap -histo
  • jmap -dump执行期间对进程产生影响很大,何时使用?
    ①可设定HeapDump参数,OOM时自动产生堆转储文件
    ②服务器高可用,停掉这台服务器对其他服务器无影响
    使用MAT / jhat进行dump文件分析
    https://www.cnblogs.com/baihuitestsoftware/articles/6406271.html
    分析工具
    1.visualvm(测试压测时使用)
    2.arthas
    3.jprefiler(收费)

实例分析

实例分析2

在这里插入图片描述

JVM调优参数设置原则

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值