关于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专栏 —— 哈哈哈,我自己的专栏;










版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

java分页

////////////////////////////////////////////////////在struts中分页的一种实现/////////////////////////////////...

Java枚举 —— 很少被使用,或许是因为真正了解它的人太少了

你代码中的flag和status,都应该用枚举Enum来替代

springboot实战:我们的第一款开源软件

在信息爆炸时代,如何避免持续性信息过剩,使自己变得专注而不是被纷繁的信息所累?每天会看到各种各样的新闻,各种新潮的技术层出不穷,如何筛选出自己所关心的?各位看官会想,我们是来看开源软件的,你给我扯什么...

Springboot(一):入门篇

什么是spring bootSpring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不...

史上最简单的 Spring MVC 教程(二)

1 前言 在史上最简单的 Spring MVC 教程(一)中,咱们已经成功搭建起 Spring MVC 框架,并且运行成功。在本篇博客中,咱们首先尝试着对前面的程序进行修改,即修改“action-s...

springboot(五):spring data jpa的使用

在上篇文章构建微服务:Spring boot 提高篇中简单介绍了一下spring data jpa的基础性使用,这篇文章将更加全面的介绍spring data jpa 常见用法以及注意事项前几篇文章地...

用小说的形式讲解Spring(2) —— 注入方式哪家强

构造器注入和set注入,到底选哪个好呢

用小说的形式讲解Spring(1) —— 为什么需要依赖注入

菜鸟大雄是如何偶遇Spring的

对list进行分页

@Override  /**   * 用list作分页   * @author zw   * @pramati.d 保存每次请求过来的 pagesize 和 当前要显示的页码   * @p...

List集合进行界面分页

最近做统计报表,查询出来的数据并不是客户所想要的数据,需要再计算,比如,你可以查询出本期的数据,数据里有很多字段,每个字段中又有很多数值。查询出来的结果只有单纯的数值,如果我们还要在界面中,每一个字段...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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