生产环境 JVM 参数配置

参数配置

废话不多说,直接给出参数配置,根据自己项目适当调整即可使用

ruby 复制代码
java -Xms4g -Xmx4g -Xmn1512m -server -Xss256k -XX:MetaspaceSize=256M  -XX:MaxMetaspaceSize=256m -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/data/log/gclog/gc.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/log/jvmdump/ -XX:+UseConcMarkSweepGC -XX:+UseParNewGC  -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=0 -XX:+CMSClassUnloadingEnabled -XX:+TieredCompilation  -XX:+ExplicitGCInvokesConcurrentAndUnloadsClasses -jar xxx.jar

此参数在以前笔者负责的一个微服务项目中运行了数年,单机并发1000+,CMS GC大概是8天左右一次

配置说明

这些JVM配置参数用于调整Java虚拟机的性能和行为。下面是对这些参数的解读:

  • -Xms4g: 设置JVM的初始堆大小为4GB。当JVM启动时,它会立即分配这么多的堆内存。

  • -Xmx4g: 设置JVM最大可用的堆内存为4GB。无论何时,JVM分配给对象的内存总量不会超过这个值。

  • -Xmn1512m: 设置年轻代大小为1512MB。年轻代是堆内存的一个子区域,用于存放新生成的对象。

  • -server: 选择server模式的JVM,针对服务器端应用进行了优化,相对于client模式,拥有更高的优化级别和更长的启动时间。

  • -Xss256k: 设置每个线程堆栈的大小为256KB。线程堆栈大小影响了线程可以调用的深度,以及能够创建的线程数量。

  • -XX:MetaspaceSize=256M: 设置元空间的初始大小为256MB。元空间用于存储类的元数据,它在Java 8中取代了永久代。

  • -XX:MaxMetaspaceSize=256m: 设置元空间的最大大小为256MB。这限制了类的元数据可用的最大内存。

  • -XX:+PrintGCDetails: 启用详细的垃圾回收日志。

  • -XX:+PrintGCDateStamps: 在垃圾回收日志中包含日期戳,以便于分析。

  • -Xloggc:/data/log/gclog/gc.log: 指定垃圾回收日志的文件路径。

  • -XX:+HeapDumpOnOutOfMemoryError: 在发生内存溢出异常时,自动进行堆转储。

  • -XX:HeapDumpPath=/data/log/jvmdump/: 指定堆转储文件的存储路径。

  • -XX:+UseConcMarkSweepGC: 启用CMS(并发标记清除)垃圾收集器。

  • -XX:+UseParNewGC: 使用ParNew(并行新生代)垃圾收集器。这通常与-XX:+UseConcMarkSweepGC一起使用,作为老年代垃圾收集器的补充。

  • -XX:CMSInitiatingOccupancyFraction=75: 设置堆使用到75%时,就开始进行CMS垃圾回收。

  • -XX:+UseCMSInitiatingOccupancyOnly: 只在达到-XX:CMSInitiatingOccupancyFraction指定的占用率时才启动CMS收集,不基于运行时间。

  • -XX:+UseCMSCompactAtFullCollection: 在进行完全垃圾收集时启用CMS的压缩步骤。

  • -XX:CMSFullGCsBeforeCompaction=0: 设置在执行多少次CMS完全垃圾回收后进行一次压缩。

  • -XX:+CMSClassUnloadingEnabled: 允许CMS收集器卸载无用的类。

  • -XX:+TieredCompilation: 启用分层编译,这允许JVM在执行Java代码时使用多个编译级别,以提高性能。

  • -XX:+ExplicitGCInvokesConcurrentAndUnloadsClasses: 允许显式垃圾回收调用(如System.gc())触发并发收集和类的卸载,而不是导致完全的垃圾收集。

这些参数的组合是为了让JVM在服务器环境中以较大的堆内存启动,并具有高吞吐量的垃圾回收策略。同时它们也确保了在OOM错误发生时能够获取到堆的快照,这有助于之后分析和解决内存问题。

相关推荐
CodeSheep2 分钟前
小米汽车这薪资是认真的吗?
前端·后端·程序员
今天背单词了吗9805 分钟前
算法学习笔记:8.Bellman-Ford 算法——从原理到实战,涵盖 LeetCode 与考研 408 例题
java·开发语言·后端·算法·最短路径问题
天天摸鱼的java工程师8 分钟前
使用 Spring Boot 整合高德地图实现路线规划功能
java·后端
阿杆9 分钟前
😡同事查日志太慢,我现场教他一套 grep 组合拳!
linux·后端
PetterHillWater10 分钟前
基于Trae智能复杂项目重构实践
后端·aigc
凌览24 分钟前
有了 25k Star 的MediaCrawler爬虫库加持,三分钟搞定某红书、某音等平台爬取!
前端·后端·python
这里有鱼汤35 分钟前
给你的DeepSeek装上实时行情,让他帮你炒股
后端·python·mcp
咖啡啡不加糖37 分钟前
暴力破解漏洞与命令执行漏洞
java·后端·web安全
风象南40 分钟前
SpringBoot敏感配置项加密与解密实战
java·spring boot·后端
ん贤1 小时前
RESTful风格
后端·go·restful