我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java垃圾回收调优的方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java垃圾回收调优的方法是什么

这篇文章主要讲解了“Java垃圾回收调优的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java垃圾回收调优的方法是什么”吧!

性能调优目标要是可确定且可测量的,这非常重要。这些目标包括延迟、吞吐量和容量,想要了解更多,我推荐看看垃圾回收手册(Garbage Collection Handbook)中相应的章节。让我们看看在实践中如何设定并达到这样的调优目标。为了这个目的,让我们来看一个示例代码:

//imports skipped for brevity public class Producer implements Runnable {    private static ScheduledExecutorService executorService = Executors.newScheduledThreadPool(2);    private Deque<byte[]> deque;   private int objectSize;   private int queueSize;    public Producer(int objectSize, int ttl) {     this.deque = new ArrayDeque<byte[]>();     this.objectSize = objectSize;     this.queueSize = ttl * 1000;   }    @Override   public void run() {     for (int i = 0; i < 100; i++) {       deque.add(new byte[objectSize]);       if (deque.size() > queueSize) {         deque.poll();       }     }   }    public static void main(String[] args) throws InterruptedException {     executorService.scheduleAtFixedRate(new Producer(200 * 1024 * 1024 / 1000, 5), 0, 100, TimeUnit.MILLISECONDS);     executorService.scheduleAtFixedRate(new Producer(50 * 1024 * 1024 / 1000, 120), 0, 100, TimeUnit.MILLISECONDS);     TimeUnit.MINUTES.sleep(10);     executorService.shutdownNow();   } }

代码中提交了两个作业(job),且每 100ms 运行一次。每个作业模拟特定对象的生命周期:先创建对象,让它们“存活”一段时间,然后忘记它们,让 GC 回收内存。 运行这个示例时,开启 GC 日志并使用以下参数:

-XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps

我们立即在日志文件中看到 GC 的影响和下面这些相似:

2015-06-04T13:34:16.119-0200: 1.723: [GC (Allocation Failure) [PSYoungGen: 114016K->73191K(234496K)] 421540K->421269K(745984K), 0.0858176 secs] [Times: user=0.04 sys=0.06, real=0.09 secs] 2015-06-04T13:34:16.738-0200: 2.342: [GC (Allocation Failure) [PSYoungGen: 234462K->93677K(254976K)] 582540K->593275K(766464K), 0.2357086 secs] [Times: user=0.11 sys=0.14, real=0.24 secs] 2015-06-04T13:34:16.974-0200: 2.578: [Full GC (Ergonomics) [PSYoungGen: 93677K->70109K(254976K)] [ParOldGen: 499597K->511230K(761856K)] 593275K->581339K(1016832K), [Metaspace: 2936K->2936K(1056768K)], 0.0713174 secs] [Times: user=0.21 sys=0.02, real=0.07 secs]

基于日志中的信息,我们可以开始改善性能。并请牢记三个不同的目标:

  1. 确保 GC pause(垃圾回收暂停)的最坏情况不要超过预期的临界值。

  2. 确保应用程序线程停滞时间不超过预先确定的阀值。

  3. 降低基础架构成本,同时确保我们仍可以实现合理的延迟和吞吐量目标。

为此,以三个不同的配置各运行了10分钟,在下表中总结了三个差距较大的结果:

GC算法

有效工作

长暂停

-Xmx12g

-XX:+UseConcMarkSweepGC

8%

560 ms

-Xmx12g

-XX:+UseParallelGC

5%

1,104 ms

-Xmx8g

-XX:+UseConcMarkSweepGC

3%

1,610 ms

实验中,设置不同的 GC 算法和不同的堆大小,运行相同的代码,然后测量垃圾回收暂停的持续时间和吞吐量。实验细节和结果的解释都在我们的垃圾回收手册中。看看手册中的一些例子,修改一些简单的配置造成延迟、吞吐量等各方面的性能完全不同。

注意:为了保持示例尽可能简单,只有数量有限的输入参数被改变,例如没有对不同数量的核心(CPU core)或不同堆布局进行测试。

感谢各位的阅读,以上就是“Java垃圾回收调优的方法是什么”的内容了,经过本文的学习后,相信大家对Java垃圾回收调优的方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java垃圾回收调优的方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java垃圾回收调优的方法是什么

这篇文章主要讲解了“Java垃圾回收调优的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java垃圾回收调优的方法是什么”吧!性能调优目标要是可确定且可测量的,这非常重要。这些目标
2023-06-17

Java应用的垃圾回收优化方法是什么

这篇文章主要讲解了“Java应用的垃圾回收优化方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java应用的垃圾回收优化方法是什么”吧!高性能应用构成了现代网络的支柱。LinkedI
2023-06-17

Java垃圾回收机制是什么

这篇文章主要介绍“Java垃圾回收机制是什么”,在日常操作中,相信很多人在Java垃圾回收机制是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java垃圾回收机制是什么”的疑惑有所帮助!接下来,请跟着小编
2023-06-17

JVM调优中垃圾回收面临的问题是什么

这篇文章将为大家详细讲解有关JVM调优中垃圾回收面临的问题是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。如何区分垃圾上面说到的“引用计数”法,通过统计控制生成对象和删除对象时的引用数来
2023-06-17

jvm垃圾回收GC调优基础原理是什么

这篇文章主要介绍了jvm垃圾回收GC调优基础原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jvm垃圾回收GC调优基础原理是什么文章都会有所收获,下面我们一起来看看吧。说明:Capacity: 性能,能
2023-06-29

Java中的垃圾回收机制是如何工作的?如何优化Java的垃圾回收?(Java的垃圾回收器如何运作?有哪些策略可以优化Java的垃圾回收性能?)

Java垃圾回收机制通过根引用扫描、图遍历、标记和清除过程回收不再使用的对象。优化策略包括减少对象分配、使用大对象、避免循环引用、调整GC参数和使用最新JVM版本。监控GC性能并根据特定需求优化策略至关重要。
Java中的垃圾回收机制是如何工作的?如何优化Java的垃圾回收?(Java的垃圾回收器如何运作?有哪些策略可以优化Java的垃圾回收性能?)
2024-04-02

怎么进行Java内存与垃圾回收调优

本篇文章给大家分享的是有关怎么进行Java内存与垃圾回收调优,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。要了解Java垃圾收集机制,先理解JVM内存模式是非常重要的。今天我们
2023-06-17

JVM垃圾回收器是什么

这篇文章主要讲解了“JVM垃圾回收器是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JVM垃圾回收器是什么”吧!并发与并行并行(Parallel):并行描述的是多条垃圾收集器线程之间的关
2023-07-02

Java垃圾回收机制的原理是什么

本篇内容主要讲解“Java垃圾回收机制的原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java垃圾回收机制的原理是什么”吧!Java 垃圾回收机制1. 垃圾回收主要关注 Java 堆图
2023-06-15

PHP垃圾回收机制是什么

本篇内容主要讲解“PHP垃圾回收机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP垃圾回收机制是什么”吧!PHP的垃圾回收机制垃圾回收机制是一种动态存储分配的方案。它会自动释放程序不
2023-06-20

jvm回收垃圾的机制是什么

JVM(Java虚拟机)使用自动垃圾回收(Garbage Collection)机制来管理和回收不再使用的对象的内存。以下是JVM垃圾回收的机制:1. 引用计数:这是一种最简单的垃圾回收机制,它通过对每个对象维护一个引用计数器来记录当前有多
2023-08-30

go垃圾回收机制是什么

go语言中的垃圾回收机制是指自动管理内存分配和释放的机制。在Go语言中,开发者不需要手动去分配和释放内存,而是由垃圾回收机制自动进行管理。Go语言的垃圾回收器采用了并发标记清除(concurrent mark and sweep)的算法,
2023-10-25

python垃圾回收机制是什么

Python的垃圾回收机制是自动化的,它使用了引用计数和循环垃圾收集两种方法。1. 引用计数:Python中的每个对象都有一个引用计数器,用来记录有多少个引用指向该对象。当引用计数器为0时,说明没有任何引用指向该对象,对象就会被垃圾回收机制
2023-08-14

JVM的垃圾回收机制详解与调优

这篇文章主要讲解了“JVM的垃圾回收机制详解与调优”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JVM的垃圾回收机制详解与调优”吧!1.JVM的gc概述gc即垃圾收集机制是指jvm用于释放那
2023-06-03

python语法之垃圾回收机制是什么

本篇内容介绍了“python语法之垃圾回收机制是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一 引入解释器在执行到定义变量的语法时,会
2023-06-30

java垃圾回收算法怎么应用

Java中的垃圾回收算法是通过自动内存管理实现的,开发人员不需要手动去释放内存。Java中的垃圾回收算法主要有以下几种:1. 引用计数法(Reference Counting):每个对象都有一个引用计数器,当有引用指向该对象时计数器加1,引
2023-10-08

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录