简介

今天我们讲讲JDK10中的JVM GC调优参数,JDK10中JVM的参数总共有1957个,其中正式的参数有658个。

其实JDK10跟JDK9相比没有太大的变化,一个我们可以感受到的变化就是引入了本地变量var。

为了方便大家的参考,特意将JDK10中的GC参数总结成了一张PDF,这个PDF在之前的JDK9的基础上进行了增减和修正,欢迎大家下载。

Java参数类型

其实Java参数类型可以分为三类。

第一类叫做标准的java参数。

这一类参数是被所有的JVM实现所支持的,是一些非常常用的JVM参数。

我们可以通过直接执行java命令来查看。

第二类叫做额外的java参数,这些参数是专门为Hotspot VM准备的,并不保证所有的JVM都实现了这些参数。并且这些参数随时有可能被修改。 额外的java参数是以 -X开头的。

我们可以通过java -X来查看。

第三类叫做高级参数。这些参数是开发者选项,主要作用就是JVM调优。这些参数和第二类参数一样,也是不保证被所有的JVM支持的,并且随时都可能变化。

第三类参数是以-XX开头的,我们可以通过java -XX:+PrintFlagsFinal来查看。

神奇的是,我们做JVM调优的参数往往就是这第三类参数,所以,下次如果再有面试官问你JVM调优,你可以直接怼回去:这些参数是不被官方推荐普通使用者使用的,并且随时都可能变化。没必要掌握!那么这个Offer肯定非你莫属。

Large Pages

其实JDK10跟JDK9相比没啥大的变化,这里重点讲解一个特性叫做Large Pages。

Large pages其实不是JDK10的新特性了,它的历史已经很久了。

在讲large Pages之前,我们先讲一下内存分页。

CPU是通过寻址来访问内存空间的。一般来说CPU的寻址能力是有限的。而实际的物理内存地址会远大于CPU的寻址范围。

为了解决这个问题,现代CPU引入了MMU(Memory Management Unit 内存管理单元)和虚拟地址空间的概念。

虚拟地址空间也叫做(Virtual address space),为了不同程序的互相隔离和保证程序中地址的确定性,现代计算机系统引入了虚拟地址空间的概念。简单点讲可以看做是跟实际物理地址的映射,通过使用分段或者分页的技术,将实际的物理地址映射到虚拟地址空间。

同时为了解决虚拟空间比物理内存空间大的问题,现代计算机技术一般都是用了分页技术。

分页技术就是将虚拟空间分为很多个page,只有在需要用到的时候才为该page分配到物理内存的映射,这样物理内存实际上可以看做虚拟空间地址的缓存。

虚拟地址空间和物理地址的映射是通过一个叫做映射存储表的地方来工作的。这个地方一般被叫做页表(page table),页表是存储在物理内存中的。

CPU读取物理内存速度肯定会慢于读取寄存器的速度。于是又引入了TLB的概念。

Translation-Lookaside缓冲区(TLB)是一个页面转换缓存,其中保存了最近使用的虚拟到物理地址转换。

TLB容量是有限的。如果发生TLB miss则需要CPU去访问内存中的页表,从而造成性能损耗。

通过调大内存分页大小,单个TLB条目存储更大的内存范围。这将减少对TLB的压力,并且对内存密集型应用程序可能具有更好的性能。

但是,大页面也可能会对系统性能产生负面影响。例如,当应用程序使用大量大页面内存时,可能会导致常规内存不足,并导致其他应用程序中的过多分页,并使整个系统变慢。同样,长时间运行的系统可能会产生过多的碎片,这可能导致无法保留足够大的页面内存。发生这种情况时,OS或JVM都会恢复为使用常规页面。

Oracle Solaris, Linux, and Windows Server 2003 都支持大页面。

具体各个系统的large page的配置,大家可以自行探索。

JIT调优

JIT我在之前的文章中介绍过很多次了,为了提升java程序的执行效率,JVM会将部分热点代码,使用JIT编译成为机器码。

那么JIT的调试参数也是非常重要的。这里具体讲解一些比较常用JIT调试指令:

-XX:+BackgroundCompilation

使用后台编译,也就是说编译线程和前台线程使用是不同的线程。一般来说如果我们需要调试JIT日志的话,需要关闭此选项。

-XX:CICompilerCount=threads

设置编译线程的个数。

-XX:CompileCommand=command,method[,option]

自定义具体方法的编译方式。

比如:

-XX:CompileCommand=exclude,java/lang/String.indexOf

意思是把String的indexOf exclude from compiled。

这里的command有下面几种:

  • break - 为编译设置断点
  • compileonly - exclude所有的方法,除了指定的方法
  • dontinline - 指定的方法不inline
  • exclude - 编译的时候排除指定的方法
  • inline - inline指定的方法
  • log - exclude所有的方法日志,除了指定的方法
  • option - 传递一个JIT编译的参数
  • print - 输出生成的汇编代码
  • quiet - 不打印编译命令
-XX:CompileOnly=methods

指定编译某些命令。

-XX:CompileThreshold=invocations

命令经过多少次解释执行,才会被编译。默认情况下在-server模式,这个值是10,000, 在-client模式,这个值是1,500。

如果分层编译开启之后,这个值会被忽略。

-XX:+DoEscapeAnalysis

开启逃逸分析。

-XX:+Inline

开启inline特性。

-XX:+LogCompilation

输出编译日志。

-XX:+PrintAssembly

输出汇编代码。

-XX:-TieredCompilation

取消分层编译。

上图:

总结

同样的,为JDK10特意准备了一个PDF,下载链接如下:

JDK10GC-cheatsheet.pdf

本文链接:http://www.flydean.com/jdk10-gc-cheatsheet/

最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!

欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!

一张PDF了解JDK10 GC调优秘籍-附PDF下载的更多相关文章

  1. 一张PDF了解JDK11 GC调优秘籍-附PDF下载

    目录 简介 废弃的VM选项 Source-File Mode Code Heap状态分析 AppCDS 总结 简介 JDK11相比JDK10,添加了一个新的Source-File Mode,可以直接通 ...

  2. 一张PDF了解JDK9 GC调优秘籍-附PDF下载

    目录 简介 Oracle中的文档 JDK9中JVM参数的变化 废弃的JVM选项 不推荐(Deprecated)的JVM选项 被删除的JVM参数 JDK9的新特性Application Class Da ...

  3. 一文了解JDK12 13 14 GC调优秘籍-附PDF下载

    目录 简介 那些好用的VM参数 G1的变化 配置FlightRecorder RAM参数 JDK13中的ZGC RTM支持 总结 简介 想了解JDK12,13,14中的GC调优秘籍吗?想知道这三个版本 ...

  4. 八张图彻底了解JDK8 GC调优秘籍-附PDF下载

    目录 简介 分代垃圾回收器的内存结构 JDK8中可用的GC 打印GC信息 内存调整参数 Thread配置 通用GC参数 CMS GC G1参数 总结 简介 JVM的参数有很多很多,根据我的统计JDK8 ...

  5. JVM GC调优一则--增大Eden Space提高性能

    版权声明:本文为横云断岭原创文章,未经博主同意不得转载.微信公众号:横云断岭的专栏 https://blog.csdn.net/hengyunabc/article/details/24924843 ...

  6. JVM GC调优一则–增大Eden Space提高性能

    缘起 线上有Tomcat升级到7.0.52版,然后有应用的JVM FullGC变频繁,在高峰期socket连接数,Cpu使用率都暴增. 思路 思路是Tomcat本身的代码应该是没有问题的,有问题的可能 ...

  7. JVM系列(四)之GC调优

    JVM内存参数调优 为什么要GC调优? 或者说的更确切一些,对于基于Java的服务,是否有必要优化GC?应该说,对于所有的基于Java的服务,并不总是需要进行GC优化,但当你的系统时常报了内存溢出或者 ...

  8. Java GC 专家系列3:GC调优实践

    本篇是”GC专家系列“的第三篇.在第一篇理解Java垃圾回收中我们学习了几种不同的GC算法的处理过程,GC的工作方式,新生代与老年代的区别.所以,你应该已经了解了JDK 7中的5种GC类型,以及每种G ...

  9. GC参考手册 —— GC 调优(基础篇)

    GC调优(Tuning Garbage Collection)和其他性能调优是同样的原理.初学者可能会被 200 多个 GC参数弄得一头雾水, 然后随便调整几个来试试结果,又或者修改几行代码来测试.其 ...

随机推荐

  1. 非线性规划的Matlab 解法

    编写M 文件fun1.m 定义目标函数 function f=fun1(x); % 定义目标函数 f=sum(x.^)+; % .^2是矩阵中的每个元素都求平方.^2是求矩阵的平方或两个相同的矩阵相乘 ...

  2. [每日一题2020.06.07]codeforces Round #627 (Div. 3)

    problem A /* * Author: RoccoShi * Time: 2020-06-07 19:37:51 */ #include <bits/stdc++.h> using ...

  3. STL sort的comp函数注意事项

    今天写了个题,结果碰巧re了,我眉头一皱发现事情并不简单. 原来我之前的comp写的都是错的. bool cmp(milkman a,milkman b) { return a.price<=b ...

  4. Flume-0.9.4和Hbase-0.96整合

    这几天由于项目的需要,需要将Flume收集到的日志插入到Hbase中,有人说,这不很简单么?Flume里面自带了Hbase sink,可以直接调用啊,还用说么?是的,我在本博客的<Flume-1 ...

  5. TensorFlow从0到1之TensorFlow实现单层感知机(20)

    简单感知机是一个单层神经网络.它使用阈值激活函数,正如 Marvin Minsky 在论文中所证明的,它只能解决线性可分的问题.虽然这限制了单层感知机只能应用于线性可分问题,但它具有学习能力已经很好了 ...

  6. 使用三台云服务器搭建真正的Redis集群

    三台云服务器搭建redis集群# 今天花了一天的时间弄集群redis:遇到了很多坑,从头开始吧 环境讲解: 两台配置:1核2G,另一台:1核1G: 操作系统:Centos 7.6 Redis:3.2. ...

  7. rust 宏

    macro_rules! four { () => {1 + 3}; } fn main(){ println!("{}", 1+four!()); println!(&qu ...

  8. Andrew Ng - 深度学习工程师 - Part 1. 神经网络和深度学习(Week 4. 深层神经网络)

     =================第2周 神经网络基础=============== ===4.1  深层神经网络=== Although for any given problem it migh ...

  9. Redis安装过程jemalloc/jemalloc.h报错

    问题: [root@localhost redis-3.0.0]# make cd src && make all make[1]: Entering directory `/data ...

  10. git和github入门指南(2.1)

    2.git常用命令 2.1.git的三个区 1.工作区 工作区就是你项目所在目录,这个目录是可以非常直观的看到的,编写代码主要在这个目录进行,例如: 2.暂存区 暂存区从字面上去理解就是用来暂时保存项 ...