关于Java虚拟机性能调优的清单

原创 2017年09月03日 16:15:41

导语

通过前面的学习,你已经了解了Java虚拟机的运行时数据区域还有垃圾收集的内幕,从理论上来讲,你已经可以对内存溢出、垃圾收集时间过长等问题进行调优,当然,你还需要一些工具,来提高你调优的效率,因此,这一讲,给你整理了Java虚拟机性能调优所需要的全部资料的清单,方便你在调优时进行查找,而在下一讲,我们就将使用这个清单,来进行调优实战训练。

本文是Effective Java专栏Java虚拟机专题的第八讲,如果你觉得看完之后对你有所帮助,欢迎订阅本专栏,也欢迎您将本专栏分享给你身边的工程师同学。


理论知识

任何实战都是建立在扎实的理论基础上的,尤其是计算机科学,你别想着能够像牛顿那样坐着一动不动就会有苹果去砸他然后发现万有引力,面对着一台电脑,你不动,它岿然不动也。

要想对Java虚拟机进行内存调优,这些前置课程是你必须要学习的:


Java HotSpot 虚拟机参数清单

在虚拟机调优的过程中,我们需要指定垃圾收集器、指定垃圾收集器的配置,这些都需要我们对虚拟机参数进行配置。HotSpot虚拟机提供了很多参数给用户对其进行配置,比如之前所讲的-client、-Xmx等(如何使用这些参数?),这些参数可以分为两种:标准的(standard)和非标准的(non-standard),其中非标准的都分为-X和-XX开头两种,X的含义和《X战警》里的X是一样的,代表未知的意思,X越多,说明这种参数的不稳定性越高。

  • 标准参数:这些参数非常稳定,并且HotSpot保证在后面的版本中会一直存在,比如-client、-server、-version等。
  • -X参数:这些参数以-X开头,Java不保证在所有虚拟机实现中都可以使用。
  • -XX参数: 这些参数以-XX开头,比-X更加不稳定(可能有bug的意思)。

这些参数的介绍,可以在Oracle的官网中查看,传送门:Java HotSpot VM Options


Java虚拟机性能监控和故障处理工具

了解了上面这些基本的理论知识,现在你需要一些强力的工具,来帮助你分析虚拟机的性能。

打开Java安装目录下的bin文件夹,你会看到除了我们常用的java和javac,居然还有很多其他的文件:


这些工具里面,有不少是Java提供的用于监控虚拟机运行状况的,既有命令行工具,如jstackjmap这两个特别常用的命令,也有像Visual VMJConsole这样的图形化界面。同样的,我给你找到了Oracle上对这些工具最原汁原味的讲解,传送门:Java Platform, Standard Edition Troubleshooting Guide - Diagnostic Tools


当然,JDK没有提供对jmap命令产生的dump文件的图形化界面,只提供了jhat命令来分析,对于dump文件的图形化工具,你可以使用eclipse memory analyer.


总结

这一讲,归纳总结了进行虚拟机调优的必备知识清单,方便你在调优时对照着进行参考,同时,我们也将在下一讲,利用这份清单,来进行一个Java虚拟机调优实战训练。


干货分享

文末分享一下一些关于虚拟机调优的好文章:

HotSpot Virtual Machine Garbage Collection Tuning Guide —— Oracle官网上的,权威、原汁原味的介绍了垃圾收集器的;

Tuning Java Virtual Machines (JVMs) —— 也是Oracle官网上的,相比于上一篇,这一篇少了写理论,更多的是经验和实战的指导;

《深入理解Java虚拟机》 —— 国内虚拟机的经典之作,豆瓣评分8.7、亚马逊4.2、京东自营计算机与互联网销量榜 第17位(我觉得我可以去搞一下图书查询APP);

Java Performance Tuning, Profiling, and Memory Management —— DZone上的一篇文章,国内我还没看到有写的既清晰又有深度的博客;

CSDN Effective Java专栏 —— 哈哈哈,我自己的专栏;










版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hzy38324/article/details/77799115

Java虚拟机监控指标及监控配置

主要是对Java虚拟机(JVM)的远程监视,如jdk自带的工具jvisualvm就可监视内存(JVM)、垃圾收集(GC)和线程统计,针对不同的JVM厂商,如Sun JVM、IBM JVM和Oracle...
  • smooth00
  • smooth00
  • 2017-04-28 20:20:43
  • 5424

(一)Java虚拟机基础详解

我的第一份博客,虚拟机的开始!
  • u013035972
  • u013035972
  • 2016-05-14 11:08:53
  • 698

介绍几个java虚拟机性能监测工具

这些工具都在%JDK_HOME%/bin下. jdk5.0以上基本都有这些工具. jconsole: 是一个图形化的工具, 可以连接至本地或remote的虚拟机, 提供实时的性能视图和资源消耗信息. ...
  • sunxing007
  • sunxing007
  • 2010-08-31 17:51:00
  • 1324

Java虚拟机性能管理神器 - VisualVM(4) - JDK版本与VisualVM版本对应关系

VisualVM - JAVA 监控工具(4)    JDK版本与VisualVM版本对应关系说明 JDK版本与VisualVM版本对应关系 VisualVM 相应的Java VisualVM...
  • chwshuang
  • chwshuang
  • 2015-03-11 16:38:07
  • 1881

果学院jvm性能调优、内存模型、虚拟机原理全部高清、完整版共110集视频

  • 2018年01月29日 11:33
  • 161B
  • 下载

龙果学院深入理解Java虚拟机(jvm性能调优+内存模型+虚拟机原理

  • 2018年02月23日 14:13
  • 52B
  • 下载

关于Java虚拟机性能调优的清单

关于Java虚拟机性能调优,你所需要知道的知识,都在这里了。
  • hzy38324
  • hzy38324
  • 2017-09-03 16:15:41
  • 1954

JAVA虚拟机优化实战

最近项目要上线了,可是压力测试总不过关,找到一篇不错的文章分享下: 堆内存设置 原理 JVM堆内存分为2块:Permanent Space 和 Heap Space。 ...
  • whitevampire
  • whitevampire
  • 2016-09-08 17:06:04
  • 577

Java虚拟机的性能监控与调优

3 JVM的性能监控 3.1 监控的指标和工具 3.1.2  jps:虚拟机进程状况工具 利用jps工具可以显示当前虚拟机中运行的java进程,并且jps后面可以跟参数,-l是输出主类名,-v可以输出...
  • u014574317
  • u014574317
  • 2017-06-03 11:37:43
  • 625

深入理解Java虚拟机视频教程(jvm性能调优+内存模型+虚拟机原理)视频教程

  • 2018年01月19日 11:07
  • 51B
  • 下载
收藏助手
不良信息举报
您举报文章:关于Java虚拟机性能调优的清单
举报原因:
原因补充:

(最多只允许输入30个字)