`
yanwt
  • 浏览: 98799 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JVM性能优化

阅读更多
sun公司的性能优化白皮书中提到的几个例子:
1.对于吞吐量的调优。机器配置:4G的内存,32个线程并发能力。
java -Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20
       -Xmx3800m -Xms3800m 配置了最大Java Heap来充分利用系统内存。
       -Xmn2g 创建足够大的青年代(可以并行被回收)充分利用系统内存,防止将短期对象复制到老年代。
    -Xss128 减少默认最大的线程栈大小,提供更多的处理虚拟内存地址空间被进程使用。
    -XX:+UseParallelGC 采用并行垃圾收集器对年青代的内存进行收集,提高效率。
    -XX:ParallelGCThreads=20 减少垃圾收集线程,默认是和服务器可支持的线程最大并发数相同,往往不需要配置到最大值。
2.尝试采用对老年代并行收集
java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20 -XX:+UseParallelOldGC
-Xmx3550m -Xms3550m 内存分配被减小,因为ParallelOldGC会增加对于Native Heap的需求,因此需要减小Java Heap来满足需求。
-XX:+UseParallelOldGC 采用对于老年代并发收集的策略,可以提高收集效率。
3.提高吞吐量,减少应用停顿时间
java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:SurvivorRatio=8 -XX:TargetSurvivorRatio=90 -XX:MaxTenuringThreshold=31
-XX:+UseConcMarkSweepGC -XX:+UseParNewGC 选择了并发标记交换收集器,它可以并发执行收集操作,降低应用停止时间,同时它也是并行处理模式,可以有效地利用多处理器的系统的多进程处理。
-XX:SurvivorRatio=8 -XX:MaxTenuringThreshold=31 表示在青年代中Eden和Survivor比例,设置增加了Survivor的大小,越大的survivor空间可以允许短期对象尽量在年青代消亡。
-XX:TargetSurvivorRatio=90 允许90%的空间被占用,超过默认的50%,提高对于survivor的使用率。
类似的例子网上很多,这儿就不在列下来了,最终是否采取自己配置来替换默认配置还是要根据虚拟机的使用情况来分析和配置。

分享到:
评论

相关推荐

    Jvm性能优化-JVM内存结构原理分析03

    "Jvm性能优化-JVM内存结构原理分析03" Jvm性能优化是Java虚拟机(JVM)中非常重要的一部分,它对Jvm的性能产生了很大的影响。本文将从Jvm内存结构的角度来分析Jvm性能优化的原理。 Jvm内存结构主要分为五部分:堆...

    JVM性能优化(PPT)

    **JVM性能优化** 在Java开发中,JVM(Java Virtual Machine)是至关重要的组成部分,它负责运行所有的Java应用程序。JVM性能优化是一项细致而关键的任务,能够显著提升程序的运行效率,减少资源消耗,提高系统稳定...

    JVM性能优化笔记

    JVM性能优化笔记 ------------------------------------------

    JVM性能优化相关问题.pdf

    本次分享的内容将涵盖Java类的加载过程、类加载机制、内存分配和垃圾收集机制等关键知识点,这些内容对于理解Java程序的性能优化至关重要。 首先,我们来探讨Java类加载的过程,这个过程包括了加载、验证、准备、...

    面试必问之jvm与性能优化.docx

    ### jvm性能优化相关知识点详解 #### 一、JVM加载Class文件的原理机制 **1.1 类加载概述** Java虚拟机(JVM)在执行Java程序时,并不会一次性加载所有的类,而是采取按需加载的方式。这种方式可以有效减少内存消耗...

    JVM性能优化相关问题

    以下是一些关于JVM性能优化的关键知识点: 1. **内存管理:** - **堆内存**:Java对象主要存储在堆内存中,分为新生代(Young Generation)和老年代(Old Generation)。新生代又细分为Eden区和两个Survivor区。...

    jvm性能优化

    ### jvm性能优化 在Java开发领域中,JVM(Java虚拟机)的性能优化是一项至关重要的技术。通过对JVM的合理配置与调优,可以显著提升Java应用程序的运行效率和资源利用率。以下是对JVM性能优化的关键知识点的详细介绍...

    JVM性能优化相关面试题21道.pdf

    在深入探讨JVM性能优化相关面试题之前,先了解Java虚拟机(JVM)中类加载过程、JVM加载Class文件的原理机制以及Java内存分配的知识点是非常有必要的。 首先,Java类加载过程共有七个步骤,这七个步骤分别是:加载、...

    【面试资料】-(机构内训资料)JVM性能优化相关问题.zip

    JVM性能优化是提高Java应用性能的关键环节,对于开发者来说,深入理解JVM的工作原理并进行有效优化至关重要。下面我们将详细探讨JVM性能优化的相关知识点。 1. **类加载机制**:JVM通过类加载器将类的.class文件...

    JVM性能优化相关问题.zip

    JVM性能优化相关问题.zip

    jvm详细介绍以及性能优化方法

    在JVM性能优化中,我们重点关注垃圾收集(GC)和内存管理。GC的主要任务是自动回收不再使用的对象所占用的内存空间,避免内存泄漏。了解不同类型的GC算法,如串行GC、并行GC、CMS(Concurrent Mark Sweep)和G1...

    JVM系列之性能调优参考手册(实践篇).pdf

    标题《JVM系列之性能调优参考手册(实践篇)》涉及的知识点主要集中在Java虚拟机(JVM)性能调优的实践操作。...因此,手册的实践操作部分对于开发者来说是作为深入理解和应用JVM性能调优知识的参考。

    Java虚拟机JVM性能优化(一):JVM知识总结

    最后,为了更好地诊断和分析JVM性能,我们可以使用各种工具,如JVisualVM、JConsole、JProfiler等,它们可以提供内存、线程、CPU使用情况的实时监控,帮助定位问题。 总之,Java虚拟机的性能优化是一个涉及多方面...

    JVM性能优化:线程锁优化.docx

    Java虚拟机(JVM)性能优化的一个重要领域是线程锁优化,这直接影响到多线程应用程序的效率和并发性能。线程锁是确保多线程环境下数据一致性和线程安全的关键机制。以下是对线程锁优化的一些核心知识点的详细说明: ...

    JVM和性能优化学习思维笔记_swim5we_jvm_性能优化_

    这份思维笔记会深入探讨以上各个知识点,通过实例和案例分析,帮助开发者从理论到实践全面掌握JVM性能优化的技巧。通过学习和应用这些知识,不仅可以提升Java应用的运行效率,还能在面对复杂的系统问题时,更快速、...

    阿里巴巴Java性能调优实战(2021-2022华山版)+Java架构核心宝典+性能优化手册100技巧.rar

    性能优化手册是一套java性能学习研究小技巧,包含内容:Java性能优化、JVM性能优化、服务器性能优化、数据库性能优化、前端性能优化等。 内容包括但不限于: String 性能优化的 3 个小技巧 HashMap 7 种遍历方式...

    JVM性能优化值导出报表2

    在本文中,我们将深入探讨Java虚拟机(JVM)性能优化的一个具体案例,涉及的是一个批量导出功能引发的内存管理问题。这个问题涉及到的主要知识点包括Java内存模型、垃圾收集器(Garbage Collector, GC)的选择以及...

Global site tag (gtag.js) - Google Analytics