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

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 一张PDF了解JDK9 GC调优秘籍-附PDF下载

目录



简介



今天我们讲讲JDK9中的JVM GC调优参数,JDK9中JVM的参数总共有2142个,其中正式的参数有659个。好像比JDK8中的参数要少一点。


为了方便大家的参考,特意将JDK9中的GC参数总结成了一张PDF,这个PDF比之前总结的JDK8的PDF在排版,颜色和内容准确性上面又有了非常大的提升,欢迎大家下载。


Oracle中的文档



今天这篇文章的内容都是从Oracle JDK9的官方文档中提炼出来的。对于里面的内容的真实性,我不能保证是100%正确的。


有人要问了,官网文档也会有错误?


这个问题要从两个方面说起,第一方面,任何人都会犯错误,虽然官网文档经过了编辑,校验核对然后才发布,但是总会有一些遗漏的地方。


第二,Oracle的文档是有专门的写文档的部门来专门编写的,写文档就是他们的工作,所以,这些文档并不是开发JDK的开发人员编写的,而是和开发JDK不相关的文档编写员编写的。


至于文档写完之后有没有JDK开发人员过目,大家可以自行脑补......


所以古人说得好,尽信书不如无书。


JDK9中JVM参数的变化



一代新人换旧人,长江后浪推前浪。由来只有新人笑 有谁听到旧人哭。


JDK9出现了,那么JDK8中的一些参数自然需要退伍了。


我们回想一下JDK9中有些什么变化呢?我总结一下有三个。


  1. 最大的变化就是引入了JPMS(Java Platform Module System)也就是Project Jigsaw。
    模块化的本质就是将一个大型的项目拆分成为一个一个的模块,每个模块都是独立的单元,并且不同的模块之间可以互相引用和调用。
    在module中会有元数据来描述该模块的信息和该模块与其他模块之间的关系。这些模块组合起来,构成了最后的运行程序。
  2. 然后就是引入的Xlog日志服务,通过Xlog日志服务我们可以监控JVM中的事件,比如:GC,class loading,JPMS,heap,thread等等。
  3. 最后就是将String中的底层存储从char数组换成了byte数组。


这三个变化中和JVM最相关的就是第二个Xlog日志服务。


废弃的JVM选项



-Xusealtsigs / -XX:+UseAltSigs


这两个选项在JDK9中被废弃了,如果你不知道也没关系,因为这两个选项是在Oracle Solaris中专有的。现在用Solaris服务器的人应该比较少了.....


不推荐(Deprecated)的JVM选项



下面这些选项是JVM已经不再推荐使用了,如果你使用的话也没问题,但是会有报警。

Deprecated表示这些选项会在未来被删除,我们应该尽量避免使用这些选项。


选项有很多,我们挑一些比较常见和重要的来给大家讲解一下。


-d32 / -d64


为什么这两个参数会被不推荐呢?因为现在的服务器性能已经非常非常的好了。


如果你的JDK是64位的,那么默认就启用了-server和-d64模式,32位的JDK现在应该很少见到了。


Oracle官方文档说只有Java HotSpot Server VM才有64位的模式。不知道是真是假,因为其他的VM我也没有用过,没有发言权。


-Xloggc:garbage-collection.log


因为JDK9中引入Xlog框架,所以之前的日志输出的参数都被替换成了新的Xlog格式:


比如上面的命令被替换成为 -Xlog:gc:garbage-collection.log


所以那些以Print开头的GC日志输出参数都是不推荐的。我们需要使用Xlog来替代。


同样的以Trace开头的运行时日志输出参数也是不推荐的,也可以使用Xlog来替代。


-XX:+UseConcMarkSweepGC / -XX:CMS*


CMS在JDK9中是不被推荐的,所以CMS开头的参数都不要用了。


-XX:+UseParNewGC


因为ParNewGC是和CMS一起使用的,所以CMS不推荐之后,ParNewGC也是不推荐使用的。


-XX:MaxPermSize=size / -XX:PermSize=size


JDK8中,Prem区已经被移到了Metaspace,所以上面的参数可以被下面的替代:


-XX:MaxMetaspaceSize=size / -XX:MetaspaceSize=size


被删除的JVM参数


-Xincgc


增量GC在JDK9中被删除了。


-Xmaxjitcodesize=size JIT中最大的code cache大小被替换成 -

XX:ReservedCodeCacheSize


还有其他的一些CMS的参数。


JDK9的新特性Application Class Data Sharing



AppCDS的全称是Application Class-Data Sharing。主要是用来在不同的JVM中共享Class-Data信息,从而提升应用程序的启动速度。


通常来说,如果要执行class字节码,JVM需要执行下面的一些步骤:给定一个类的名字,JVM需要从磁盘上面找到这个文件,加载,并验证字节码,最后将它加载进来。


如果JVM启动的时候需要加载成百上千个class,那么需要的就不是一个小数目了。


对于打包好的jar包来说,只要jar的内容不变,那么jar包中的类的数据始终是相同的。


JVM在启动时候每次都会运行相同的加载步骤。


AppCDS的作用就是将这些能够共享的数据归类成一个存储文件,在不同的JVM中共享。

下面是AppCDS的大概工作流程:


  1. 选择要归档的class,并创建一个class的列表,用在归档中。( -XX:DumpLoadedClassList)
  2. 创建归档文件(-Xshare:dump和-XX:SharedArchiveFile)
  3. 使用归档文件(-Xshare:on 和 -XX:SharedArchiveFile)


相应的VM参数如下:



JDK9的新特性Xlog



在java程序中,我们通过日志来定位和发现项目中可能出现的问题。在现代java项目中,我们使用log4j或者slf4j,Logback等日志记录框架来处理日志问题。


JVM是java程序运行的基础,JVM中各种事件比如:GC,class loading,JPMS,heap,thread等等其实都可以有日志来记录。通过这些日志,我们可以监控JVM中的事件,并可以依次来对java应用程序进行调优。


在JDK9中引入的Xlog日志服务就是为这个目的而创建的。


通过xlog,JDK将JVM中的各种事件统一起来,以统一的形式对外输出。通过tag参数来区分子系统,通过log level来区分事件的紧急性,通过logging output来配置输出的地址。


在JDK9之后,之前的Print*参数都被Xlog所代替了。


我们看下常用的Xlog和GC日志参数:


 image.png


JDK9中的G1参数



作为JDK9中的默认垃圾回收器G1,对G1的调优是必不可少的。下面是G1的参数:


image.png

JDK9中的通用VM参数




下面是通用的VM参数:


image.png

JDK9中的通用GC参数



下面是JDK9中的通用GC参数:


image.png

JDK9中的内存调整参数



下面是JDK9中的内存调整参数:


image.png


总结



千言万语不如一张PDF。我把JDK9的GC参数总结成了一张PDF,下面是PDF的下载链接。

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
5月前
|
人工智能 文字识别 自然语言处理
熊猫 OCR 识别软件下载,支持截图 OCR、PDF 识别、多语言翻译的免费全能工具,熊猫OCR识别
本文介绍了几款实用的图文识别软件,包括熊猫OCR、Umi-OCR和天若OCR_本地版。熊猫OCR功能强大,支持多窗口操作、AI找图找色、OCR识别等;Umi-OCR免费且高效,具备截图OCR、批量处理等功能;天若OCR界面简洁,适合快速文字识别。文章还提供了下载链接及软件特点、界面展示等内容,便于用户根据需求选择合适的工具。
487 36
|
7月前
|
Oracle Java 关系型数据库
Tomcat和JDK的详细安装、下载和环境配置指南
以上就是JDK和Tomcat的下载、安装和环境配置的详细步骤。希望这个指南能帮助你顺利完成设置。
509 32
|
5月前
|
存储 安全 算法
Java 集合面试题 PDF 下载及高频考点解析
本文围绕Java集合面试题展开,详细解析了集合框架的基本概念、常见集合类的特点与应用场景。内容涵盖`ArrayList`与`LinkedList`的区别、`HashSet`与`TreeSet`的对比、`HashMap`与`ConcurrentHashMap`的线程安全性分析等。通过技术方案与应用实例,帮助读者深入理解集合类的特性和使用场景,提升解决实际开发问题的能力。文末附带资源链接,供进一步学习参考。
143 4
|
数据采集 Web App开发 JavaScript
Puppeteer自动化:使用JavaScript定制PDF下载
在现代Web开发中,自动化工具如Puppeteer可显著提升效率并减少重复工作。Puppeteer是一款强大的Node.js库,能够控制无头Chrome或Chromium浏览器,适用于网页快照生成、数据抓取及自动化测试等任务。本文通过示例展示了如何使用Puppeteer自动化生成定制化的PDF文件,并介绍了如何通过配置代理IP、设置user-agent和cookie等技术增强自动化过程的灵活性与稳定性。具体步骤包括安装Puppeteer、配置代理IP、设置user-agent和cookie等,最终生成符合需求的PDF文件。此技术可应用于报表生成、发票打印等多种场景。
493 6
Puppeteer自动化:使用JavaScript定制PDF下载
|
XML 缓存 JSON
为什么浏览器中有些图片、PDF等文件点击后有些是预览,有些是下载
为什么浏览器中有些图片、PDF等文件点击后有些是预览,有些是下载
609 0
|
前端开发 API
前端界面生成PDF并导出下载
【10月更文挑战第21天】利用合适的第三方库,你可以在前端轻松实现界面生成 PDF 并导出下载的功能,为用户提供更方便的文档分享和保存方式。你还可以根据具体的需求进一步优化和定制生成的 PDF 文件,以满足不同的业务场景要求。
|
Java jenkins 持续交付
Centos7下docker的jenkins下载并配置jdk与maven
通过上述步骤,您将成功在CentOS 7上的Docker容器中部署了Jenkins,并配置好了JDK与Maven,为持续集成和自动化构建打下了坚实基础。
848 1
|
监控 IDE Java
【Java性能调优新工具】JDK 22性能分析器:深度剖析,优化无死角!
【9月更文挑战第9天】JDK 22中的性能分析器为Java应用的性能调优提供了强大的支持。通过深度集成、全面监控、精细化分析和灵活报告生成等核心优势,性能分析器帮助开发者实现了对应用性能的全面掌控和深度优化。在未来的Java开发过程中,我们期待性能分析器能够继续发挥重要作用,为Java应用的性能提升贡献更多力量。
|
移动开发 前端开发 JavaScript
使用html-to-image代替html2canvas,结合jspdf实现下载pdf(下载截图下载前端dom元素)
本文介绍了在前端项目中,当使用`html2canvas`遇到问题时,如何使用`html-to-image`库作为替代方案,结合`jspdf`实现将DOM元素生成为PDF文件并提供下载。文章首先讨论了`html2canvas`可能遇到的问题,并提供了该库的使用示例代码。随后,详细介绍了`html-to-image`库的安装和使用方法,展示了如何将DOM元素转换为Canvas,再利用`jspdf`生成PDF文件。最后,文章通过示例代码说明了整个转换和下载的过程,并展示了效果截图。
1099 0
|
Arthas Prometheus 监控
使用JDK自带工具调优JVM的常用命令
使用JDK自带工具调优JVM的常用命令
200 0

热门文章

最新文章