首页 > 其他分享 >解锁 JVM 启动参数:2C4G 服务器的优化密码

解锁 JVM 启动参数:2C4G 服务器的优化密码

时间:2024-09-07 20:54:00浏览次数:15  
标签:2C4G 设置 解锁 XX 参数 垃圾 JVM 内存

在 Java 应用程序的运行过程中,JVM(Java Virtual Machine)的启动参数起着至关重要的作用。这些参数可以用来调整 JVM 的行为、优化性能、进行故障排查等。今天我们将深入探讨 JVM 的启动参数,帮助大家更好地理解和运用它们。本文将以一台配置为 2 核 CPU、4GB 内存的服务器为例,来谈谈在服务启动时,配置哪些参数最为有效。

一、内存相关

1. -Xmx和-Xms

  • -Xmx用于设置 JVM 堆的最大内存大小。合理设置这个参数可以避免内存溢出错误,但如果设置得过大,可能会导致系统资源浪费。
  • -Xms则用于设置 JVM 堆的初始内存大小。将初始内存和最大内存设置为相同的值可以避免堆内存的动态扩展,从而减少性能开销。
    如,-Xmx2048M -Xms2048M。

2. -Xmn

  • Xmn用于设置年轻代(Young Generation)的内存大小。年轻代主要用于存储新创建的对象,经过一定次数的垃圾回收后,仍然存活的对象会被移动到老年代(Old Generation)。
    如,-Xmn1024M。

3. -XX:MaxMetaspaceSize 和 -XX:MetaspaceSize

  • -XX:MaxMetaspaceSize设置元空间(Metaspace)的最大大小。元空间用于存储类信息、常量池等数据。
  • -XX:MetaspaceSize设置元空间的初始大小。如果元空间使用的内存超过了最大大小,会抛出java.lang.OutOfMemoryError: Metaspace异常。
    如,-XX:MaxMetaspaceSize512M 和 -XX:MetaspaceSize512M。

4. -XX:MaxDirectMemorySize

设置直接内存的最大大小。直接内存可以通过ByteBuffer.allocateDirect()等方法进行分配,不受 JVM 堆内存的限制。如果直接内存使用过度,也可能导致内存溢出错误。
如,-XX:MaxDirectMemorySize=256M。

二、垃圾收集相关

1. -XX:+UseConcMarkSweepGC

启用并发标记清除(Concurrent Mark Sweep)垃圾收集器。这个垃圾收集器适用于老年代的垃圾回收,它可以在应用程序运行的同时进行大部分的垃圾回收工作,从而减少垃圾回收带来的停顿时间。

2. -XX:ParallelCMSThreads

设置并发标记清除垃圾收集器的并行线程数。合理设置这个参数可以提高垃圾回收的效率。
如,-XX:ParallelCMSThreads=2。

3. XX:+CMSClassUnloadingEnabled

启用在垃圾收集时卸载类的功能。这个参数可以减少元空间的内存占用,特别是在动态加载和卸载类的应用场景中非常有用。

4. -XX:+UseCMSCompactAtFullCollection

在完全垃圾收集时启用压缩。这个参数可以减少内存碎片,提高内存的利用率。

5. -XX:CMSInitiatingOccupancyFraction

当老年代使用达到一定比例时触发垃圾收集。如,-XX:CMSInitiatingOccupancyFraction=80。

三、日志相关

1. -verbose:gc

启用详细的垃圾收集日志。

2. -XX:+PrintGCDateStamps、-XX:+PrintGCTimeStamps 和 -XX:+PrintGCDetails

-XX:+PrintGCDateStamps打印垃圾收集的日期戳。
-XX:+PrintGCTimeStamps打印垃圾收集的时间戳。
-XX:+PrintGCDetails打印垃圾收集的详细信息,包括各个内存区域的使用情况、垃圾回收的原因等。

3. -XX:+PrintTenuringDistribution

打印对象在不同年龄代的分布情况。这个参数可以帮助你了解对象在年轻代和老年代之间的晋升情况,从而优化垃圾回收策略。

4. -XX:+PrintCommandLineFlags

打印命令行中使用的 JVM 标志。这个参数可以帮助你确认 JVM 启动时实际使用的参数,方便进行故障排查和性能优化。

四、其它

1. -XX:+DisableExplicitGC

禁用显式的垃圾收集调用。在某些情况下,应用程序可能会显式地调用System.gc()方法进行垃圾回收,这可能会导致不必要的性能开销。启用这个参数可以避免这种情况。

2. -Xloggc

将垃圾收集日志输出到指定的文件。如-Xloggc:/company/log/application/gc.log。

3. -XX:ErrorFile

指定错误文件的路径。当 JVM 发生错误时,会将错误信息输出到指定的文件中。如-XX:ErrorFile::/company/log/application/err_pid.log

4. -XX:+HeapDumpOnOutOfMemoryError 和 -XX:HeapDumpPath

  • -XX:+HeapDumpOnOutOfMemoryError在发生内存溢出错误时生成堆转储文件
  • -XX:HeapDumpPath指定堆转储文件的路径。堆转储文件可以帮助你分析内存溢出的原因,从而进行故障排查和优化。
    XX:HeapDumpPath=/company/log/application/dump.prof。

五、总结

本文中,提到的举例都是以2 核 CPU、4GB 内存的服务器为例。通过合理设置这些参数,可以提高应用程序的稳定性、性能和可扩展性。在实际应用中,可以根据具体的业务需求和系统环境进行调整,不断进行性能测试和优化,以达到最佳的效果。

标签:2C4G,设置,解锁,XX,参数,垃圾,JVM,内存
From: https://blog.csdn.net/weixin_45593273/article/details/141829431

相关文章

  • 解锁AI奥秘:高效学习人工智能的十大策略
    大家好,今天给大家介绍解锁AI奥秘:高效学习人工智能的十大策略,文章末尾附有分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!可进群免费领取。解锁AI奥秘:高效学习人工智能的十大策略随着人工智能技术的飞速发展,掌握AI知识已成为许多人提升竞争力......
  • Python中的`super()`函数:解锁面向对象编程的高级技巧
    引言在面向对象的世界中,继承是一个非常重要的概念。通过继承,我们可以创建新的类来复用现有类的功能,同时还可以根据需求添加或修改功能。然而,在复杂的继承体系中,正确地调用基类的方法变得尤为重要。super()函数正是为此而生,它提供了一种简洁有效的方式来处理这类问题。本文将带你深......
  • Python中的方法重写与多态:解锁编程的无限可能
    在编程的世界里,灵活性与扩展性往往是衡量一个语言是否强大、易于维护的关键指标。Python,作为一种被广泛使用的高级编程语言,不仅以其简洁易读的语法赢得了众多开发者的喜爱,更因其支持多种面向对象特性而备受青睐。其中,“方法重写”与“多态”便是两个核心概念,它们不仅能够极......
  • Python中的方法重写与多态:解锁编程的无限可能
    在编程的世界里,灵活性与扩展性往往是衡量一个语言是否强大、易于维护的关键指标。Python,作为一种被广泛使用的高级编程语言,不仅以其简洁易读的语法赢得了众多开发者的喜爱,更因其支持多种面向对象特性而备受青睐。其中,“方法重写”与“多态”便是两个核心概念,它们不仅能够极大地提高......
  • 一键解锁企业数智化转型:JNPF低代码平台的实践与应用
    随着信息技术的飞速发展,企业面临的市场竞争日益激烈,数智化转型已成为企业持续发展的必由之路。数智化转型不仅涉及技术层面的革新,还包括业务流程、管理模式以及企业文化等多方面的深刻变革。在这一过程中,低代码平台作为一种新兴的开发工具,正逐渐成为企业实现快速转型的重要推手......
  • 一次Java性能调优实践【代码+JVM 性能提升70%】
    这是我第一次对系统进行调优,涉及代码和JVM层面的调优。如果你能看到最后的话,或许会对你日常的开发有帮助,可以避免像我一样,犯一些低级别的错误。本次调优的代码是埋点系统中的报表分析功能,小公司,开发结束后,没有CodeReview环节,所以下面某些问题,也许在CodeReview环节就可以避免......
  • Open WebUI官方库:解锁人工智能服务的官方通道
    OpenWebUI是一个开源项目,它提供了一个基于Web的用户界面,用于管理和操作各种本地和云端的人工智能模型。这个界面让用户可以方便地加载、配置、运行和监控各种AI模型,而无需编写代码或使用命令行界面。它支持多种大型语言模型(LLM),包括与Ollama和OpenAI兼容的API。Ope......
  • MTM法:解锁工时计算的科学之道,驱动制造业精益生产
    在制造业的广阔天地里,工时计算不仅是生产线高效运转的基石,更是企业精细化管理不可或缺的一环。从传统的计件制到现代精益生产的转型,每一次变革都深刻影响着工时计算的方式与方法,而深入理解并熟练运用这些方法,对于提升生产效率、优化资源配置具有重要意义。本文旨在探讨工时计算中的......
  • 一次简单的 JVM 调优
    背景最近对负责的项目进行了一次性能优化,其中包括对JVM参数的调整,算是进行了一次简单的JVM调优,JVM参数调整之后,服务的整体性能有5%左右的提升,还算不错。先介绍一下项目的基本情况:项目是一个高 QPS 压力的web服务,单机 QPS 一直维持在1.5K以上,由于旧机器的”拖累”......
  • 推荐一款流量录制回放工具:jvm-sandbox-repeater
    在软件开发和测试过程中,我们经常会遇到需要对网络请求进行录制和回放的需求,以便进行调试、测试和分析。为了模拟真实的用户请求,我们通常会使用各种流量录制回放工具来记录并重放网络请求。其中,jvm-sandbox-repeater是一款功能强大的流量录制回放工具,可以帮助我们轻松实现对网络......