为什么优化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(收费)