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

2024-02-24 16:32

本文主要是介绍一张PDF了解JDK11 GC调优秘籍-附PDF下载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 简介
  • 废弃的VM选项
  • Source-File Mode
  • Code Heap状态分析
  • AppCDS
  • 总结

简介

JDK11相比JDK10,添加了一个新的Source-File Mode,可以直接通过java来运行单个java源文件,而不需要进行编译。同时还提供了新的HTTP API,支持响应性stream。

当然上面的都不是重点,重点的是JDK11是一个LTS版本,是继JDK8之后的又一个LTS版本,也可能是大家日后使用的最多的一个版本。

所以JDK11的JVM参数吸收了JDK9,JDK10的新特性和改动,并在他们的基础上进行了微调。

同样在文章最后,我也将JDK11的GC调优秘籍做成了一张PDF,欢迎大家下载。

废弃的VM选项

JDK11和JDK9,JDK10相比,废弃的选项都差不多。这里重点讲下面几个:

-XX:+AggressiveOpts

aggressive的中文意思是激进的,有进取心的意思。这个参数的意思是启用激进的优化选项,默认情况下是禁止的,并且是作为一个体验选项提供的。

因为这个选项可能在后面的版本中作为默认选项,所以在JDK11中是废弃的。

-XX:+UseAppCDS

AppCDS是在JDK9 JPMS中引入的新特性,可以提升java程序的启动速度。

AppCDS默认情况下是开启的所以这里也废弃掉了。

注意,JVM中的参数如果是被废弃掉了,并不一定说这个选项的特性JVM已经不支持了,也有可能是JVM默认是开启了这个选项。

Source-File Mode

什么是Source-File Mode呢?

Source-File Mode就是指可以直接使用java命令来运行java源代码,而不用使用javac进行编译。

当然这个只对单文件的源代码有效。

有两种方式使用Source-File Mode,一种是源文件后面带.java后缀,如:

java HelloWorld.java

一种是添加参数–source version选项:

java -source 11 HelloWorld

这里的version指的是JDK版本号,可以取值6,7,8,9,10,11。

如果没有使用.java,则必须使用-source。

Source-File Mode的原理是将源代码编译到内存中,然后执行源代码中的第一个class。

Code Heap状态分析

我们知道JVM中的JIT编译器会将一些热点的java代码编译成机器码,而这些机器码会存储在一个叫做code cache的地方。

CodeHeap就是用来生成和管理这些机器码的类。每次存储请求都会分配一定大小的空间,这个值是由CodeCacheSegmentSize来定义的。

当然,为了提升效率,你可以将CodeCacheSegmentSize的大小设置为和cache line大小一致。不过这不是必须的。

Code Heap状态分析就是分析code cache的状态。

CodeHeap状态分析分为两个部分。 第一部分检查整个CodeHeap并汇总所有认为有用/重要的信息。 第二部分可以根据需要选的特定的命令来输出自己需要的那部分。

我们举几个例子:

实时分析:

jcmd <pid> Compiler.CodeHeap_Analytics [<function>] [<granularity>]

其中function可以有下面的几个选项:

  • all - 列出所有的信息
  • aggregate - 检查CodeHeap,并记住本地结构中的数据。
  • UsedSpace - 输出已使用的空间
  • FreeSpace - 输出空闲的空间
  • MethodCount - 输出method count信息
  • MethodSpace - 输出method space信息
  • MethodAge - 输出method age信息
  • MethodNames - 输出name信息
  • discard - 释放该方法的所有资源

granularity是和aggregate配合使用的,代表一个aggregate代表的存储空间大小。

AppCDS

JDK11在AppCDS上面有所提升,可以支持从module path导出 archiving classes:

$ java -Xshare:dump -XX:SharedClassListFile=class_list_file \-XX:SharedArchiveFile=shared_archive_file \--module-path=path_to_modular_jar -m module_name

使用:

$ java -XX:SharedArchiveFile=shared_archive_file \--module-path=path_to_modular_jar -m module_name

总结

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

JDK11GC-cheatsheet.pdf

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

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

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

这篇关于一张PDF了解JDK11 GC调优秘籍-附PDF下载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742696

相关文章

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

速了解MySQL 数据库不同存储引擎

快速了解MySQL 数据库不同存储引擎 MySQL 提供了多种存储引擎,每种存储引擎都有其特定的特性和适用场景。了解这些存储引擎的特性,有助于在设计数据库时做出合理的选择。以下是 MySQL 中几种常用存储引擎的详细介绍。 1. InnoDB 特点: 事务支持:InnoDB 是一个支持 ACID(原子性、一致性、隔离性、持久性)事务的存储引擎。行级锁:使用行级锁来提高并发性,减少锁竞争

JVM内存调优原则及几种JVM内存调优方法

JVM内存调优原则及几种JVM内存调优方法 1、堆大小设置。 2、回收器选择。   1、在对JVM内存调优的时候不能只看操作系统级别Java进程所占用的内存,这个数值不能准确的反应堆内存的真实占用情况,因为GC过后这个值是不会变化的,因此内存调优的时候要更多地使用JDK提供的内存查看工具,比如JConsole和Java VisualVM。   2、对JVM内存的系统级的调优主要的目的是减少