一张PDF了解JDK10 GC调优秘籍-附PDF下载
简介
今天我们讲讲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,下载链接如下:
最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!
一张PDF了解JDK10 GC调优秘籍-附PDF下载的更多相关文章
- 一张PDF了解JDK11 GC调优秘籍-附PDF下载
目录 简介 废弃的VM选项 Source-File Mode Code Heap状态分析 AppCDS 总结 简介 JDK11相比JDK10,添加了一个新的Source-File Mode,可以直接通 ...
- 一张PDF了解JDK9 GC调优秘籍-附PDF下载
目录 简介 Oracle中的文档 JDK9中JVM参数的变化 废弃的JVM选项 不推荐(Deprecated)的JVM选项 被删除的JVM参数 JDK9的新特性Application Class Da ...
- 一文了解JDK12 13 14 GC调优秘籍-附PDF下载
目录 简介 那些好用的VM参数 G1的变化 配置FlightRecorder RAM参数 JDK13中的ZGC RTM支持 总结 简介 想了解JDK12,13,14中的GC调优秘籍吗?想知道这三个版本 ...
- 八张图彻底了解JDK8 GC调优秘籍-附PDF下载
目录 简介 分代垃圾回收器的内存结构 JDK8中可用的GC 打印GC信息 内存调整参数 Thread配置 通用GC参数 CMS GC G1参数 总结 简介 JVM的参数有很多很多,根据我的统计JDK8 ...
- JVM GC调优一则--增大Eden Space提高性能
版权声明:本文为横云断岭原创文章,未经博主同意不得转载.微信公众号:横云断岭的专栏 https://blog.csdn.net/hengyunabc/article/details/24924843 ...
- JVM GC调优一则–增大Eden Space提高性能
缘起 线上有Tomcat升级到7.0.52版,然后有应用的JVM FullGC变频繁,在高峰期socket连接数,Cpu使用率都暴增. 思路 思路是Tomcat本身的代码应该是没有问题的,有问题的可能 ...
- JVM系列(四)之GC调优
JVM内存参数调优 为什么要GC调优? 或者说的更确切一些,对于基于Java的服务,是否有必要优化GC?应该说,对于所有的基于Java的服务,并不总是需要进行GC优化,但当你的系统时常报了内存溢出或者 ...
- Java GC 专家系列3:GC调优实践
本篇是”GC专家系列“的第三篇.在第一篇理解Java垃圾回收中我们学习了几种不同的GC算法的处理过程,GC的工作方式,新生代与老年代的区别.所以,你应该已经了解了JDK 7中的5种GC类型,以及每种G ...
- GC参考手册 —— GC 调优(基础篇)
GC调优(Tuning Garbage Collection)和其他性能调优是同样的原理.初学者可能会被 200 多个 GC参数弄得一头雾水, 然后随便调整几个来试试结果,又或者修改几行代码来测试.其 ...
随机推荐
- 动作函数-web_custom_request
web_custom_request("get_login", "URL=http://10.1.102.75:8000/login?user=Milton&pw ...
- Excel随机生成批量日期,以及注意事项
这个是WPS里写的一个函数,用来随机生成日期.首先E1和E2是两个日期端点,右键把单元格格式先设置成“日期”中的“xxxx年xx月xx日 xx:xx”,然后E3=E1-E2算出它们的距离. 在E4里面 ...
- 使用LaTeX输入矩阵
当前各种文本编辑器支持的LaTeX数学公式库大多基于KaTeX,或者在Web中用MathJax的比较多,下面给出一种在Web中输入矩阵的例子 $$\left[ \begin{array}{cccc}a ...
- 使用Vim写LaTeX代码(Vim+Vimtex+Skim)
最近在写博客的时候发现对数学公式的支持并不好,于是就想寻找一个解决方案.我本身是一个爱折腾的人,有时尽管有现成的解决方案我有事也不愿意去用.于是多方查找资料,想寻求一个自定义的解决方案,最终把自己的目 ...
- 02 . Ansible高级用法(运维开发篇)
自动化任务简介 假设我们要在10台linux服务器上安装一个nginx服务,手动是如何做的? # 第一步, ssh登录NUM(1,n)服务器 # 第二步,输入对应服务器密码 # 第三步,执行命令: y ...
- java程序员软件测试技巧
测试是开发的一个非常重要的方面,可以在很大程度上决定一个应用程序的命运.良好的测试可以在早期捕获导致应用程序崩溃的问题,但较差的测试往往总是导致故障和停机. 测试是开发的一个非常重要的方面,可以在很大 ...
- C# 人脸识别库
.NET 人脸识别库 ViewFaceCore 这是基于 SeetaFace6 人脸识别开发的 .NET 平台下的人脸识别库这是一个使用超简单的人脸识别库这是一个基于 .NET Standard 2. ...
- viewerjs 在html打开图片或打开pdf文件使用案例
开发者常用到在线访问pdf,txt,浏览图片的插件,这里推荐viewer.js这个插件,简单好用.它的核心亮点就是查看图片和pdf功能.老早以前就用过的,昨天一个小伙伴问我Android开发在线浏览p ...
- rodert单排学习redis进阶【白银一】
redis之白银一 说些题外话,最近帝都疫情又严重,大家都身处时代洪流中,这不是个别人能左右的,希望你能保护好自己,天天开心. 前言 1.Redis 客户端 1.1.Redis Desktop Man ...
- 自定义Springboot全局异常类
一.简要说明 如何实现网上文章基本是随便一搜就可以很快找到, 这里不再赘述. 二.Spring-web和Spring-webmvc 通过idea查看到两个注解位于 spring-web-5.2.2.R ...