JVM 调优常用参数(JDK1.8.0_281+CentOS7)参数1.8其他版本JDK也适用

简介: JVM 调优常用参数(JDK1.8.0_281+CentOS7)参数1.8其他版本JDK也适用

注意注意

  • -横杠开头都是标志参数(所有JVM适用)
  • -X是非标参数(本版本JDK适用)
  • -XX是不稳定参数(不稳定,可能下个小版本号的JVM就不适用了)
  1. 设置堆大小
    一般我们将两个数设置为一样的,避免因对象数量和大小的变化导致堆扩大或缩小占用宝贵的CPU计算资源。
-Xms200M   # 设置堆最“小”的大小为200M
-Xmx200M   # 设置堆最“大”的大小为200M
  1. 指定使用那种垃圾处理器组合
-XX:+UseSerialGC                     # 使用 Serial New + Serial Old 的组合垃圾回收器(淘汰)
-XX:+UseParNewGC                     # 使用 ParNew + Serial Old 组合(基本不用)
-XX:+UseConc(urrent)MarkSweepGC      # 使用 ParNew + CMS + Serial Old (响应时间优先 + 有缺陷)括号里代表有些版本要加,本版本不需要加
-XX:+UseParallelGC                   # 使用 Parallel Scavenge + Parallel Old (吞吐量优先 + JDK默认)
-XX:+UseParallelOldGC                # 同上
-XX:+UseG1GC                         # 使用 G1 垃圾回收器,一个逻辑分代物理不分代的垃圾回收器,适用于大内存(20G+)
  1. 打印打击回收日志
-XX:+PrintGC             # 打印 GC 信息
-XX:+PrintGCDetails      # 打印更加详细的 GC 信息
-XX:+PrintGCCause        # 打印 GC 原因
-XX:+PrintGCTimeStamps   # GC执行的时间戳
  1. 生成 dump 堆转储文件
-XX:+HeapDumpOnOutOfMemoryError    # 在抛出 OOM 的时候自动生成堆转储文件
# 在 Java 程序运行的时候手动生成堆转储文件,但是因为特别消耗资源,所以在生产环境中不建议使用
jps                  # 使用 jps 查看运行中的 Java 程序以及程序的进程号(PID)
jmap -dump:format=b,file={文件生成路径+文件名} {jps 命令查找之后的进程ID}   # 生成堆转储文件的命令
  1. 其他参数
-XX:+UseTLAB              # 使用 TLAB,默认打开,将 “+” 改为 “-” 则关闭
-XX:+PrintTLAB            # 打印 TLAB 的使用情况
-XX:TLABSize=2M           # 设置 TLAB 大小为2M
-XX:+DisableExplicitGC    # 禁用 System.gc() 方法,该方法执行后不会产生 FGC
-XX:+PrintHeapAtGC        # 打印 GC 堆栈情况
-XX:+PrintGCApplicationConcurrentTime   # 打印应用程序响应时长
-XX:+PrintGCApplicationStoppedTime      # 打印应用程序暂停时长
-XX:+PrintReferenceGC     # 记录回收了多少种不同引用类型的引用
-XX:+PrintVMOptions       # 打印 JVM 的参数
-XX:+PrintFlagsFinal      # 打印最终的参数
-XX:+PrintFlagsInitial    # 打印初始化默认的参数
-Xloggc:/opt/log/gc.log   # gc 日志记录
-XX:MaxTenuringThreshold=14 # 设置 GC 升代年龄为14,默认和最大都是15
# 以下两个参数建议默认就好,不要设置
-XX:PreBlockSpin=9          # 设置 synchronize 锁升级当中自旋锁的自旋次数(本版本已被废弃,之前版本可以使用,具体哪个版本可自行实验)
-XX:CompileThreshold=10001  # 设置热点代码检测阈值 
  1. Parallel 垃圾回收器常用参数
-XX:SurvivorRatio=6       # 新生代中各区比例,默认 8:1:1,改参数被设定为 6:1:1,因为 from 区和 to 区的大小必须为 2 的整数次幂,所以数值会有偏差
-XX:ParallelGCThreads=8  # 并行收集器的线程数,同样适用于 CMS,一般设为和 CPU 核数相同

有很多省略,欢迎评论区补充

相关文章
|
28天前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
2月前
|
Oracle 安全 Java
深入理解Java生态:JDK与JVM的区分与协作
Java作为一种广泛使用的编程语言,其生态中有两个核心组件:JDK(Java Development Kit)和JVM(Java Virtual Machine)。本文将深入探讨这两个组件的区别、联系以及它们在Java开发和运行中的作用。
89 1
|
2月前
|
Java 编译器 API
深入解析:JDK与JVM的区别及联系
在Java开发和运行环境中,JDK(Java Development Kit)和JVM(Java Virtual Machine)是两个核心概念,它们在Java程序的开发、编译和运行过程中扮演着不同的角色。本文将深入解析JDK与JVM的区别及其内在联系,为Java开发者提供清晰的技术干货。
35 1
|
2月前
|
Java
JVM内存参数
-Xmx[]:堆空间最大内存 -Xms[]:堆空间最小内存,一般设置成跟堆空间最大内存一样的 -Xmn[]:新生代的最大内存 -xx[use 垃圾回收器名称]:指定垃圾回收器 -xss:设置单个线程栈大小 一般设堆空间为最大可用物理地址的百分之80
|
2月前
|
监控 Java 编译器
Java虚拟机调优指南####
本文深入探讨了Java虚拟机(JVM)调优的精髓,从内存管理、垃圾回收到性能监控等多个维度出发,为开发者提供了一系列实用的调优策略。通过优化配置与参数调整,旨在帮助读者提升Java应用的运行效率和稳定性,确保其在高并发、大数据量场景下依然能够保持高效运作。 ####
35 1
|
2月前
|
存储 算法 Java
JVM进阶调优系列(10)敢向stop the world喊卡的G1垃圾回收器 | 有必要讲透
本文详细介绍了G1垃圾回收器的背景、核心原理及其回收过程。G1,即Garbage First,旨在通过将堆内存划分为多个Region来实现低延时的垃圾回收,每个Region可以根据其垃圾回收的价值被优先回收。文章还探讨了G1的Young GC、Mixed GC以及Full GC的具体流程,并列出了G1回收器的核心参数配置,帮助读者更好地理解和优化G1的使用。
|
2月前
|
监控 Java 测试技术
Elasticsearch集群JVM调优垃圾回收器的选择
Elasticsearch集群JVM调优垃圾回收器的选择
58 1
|
2月前
|
Arthas 监控 Java
JVM进阶调优系列(9)大厂面试官:内存溢出几种?能否现场演示一下?| 面试就那点事
本文介绍了JVM内存溢出(OOM)的四种类型:堆内存、栈内存、元数据区和直接内存溢出。每种类型通过示例代码演示了如何触发OOM,并分析了其原因。文章还提供了如何使用JVM命令工具(如jmap、jhat、GCeasy、Arthas等)分析和定位内存溢出问题的方法。最后,强调了合理设置JVM参数和及时回收内存的重要性。
|
2月前
|
监控 Java 编译器
Java虚拟机调优实战指南####
本文深入探讨了Java虚拟机(JVM)的调优策略,旨在帮助开发者和系统管理员通过具体、实用的技巧提升Java应用的性能与稳定性。不同于传统摘要的概括性描述,本文摘要将直接列出五大核心调优要点,为读者提供快速预览: 1. **初始堆内存设置**:合理配置-Xms和-Xmx参数,避免频繁的内存分配与回收。 2. **垃圾收集器选择**:根据应用特性选择合适的GC策略,如G1 GC、ZGC等。 3. **线程优化**:调整线程栈大小及并发线程数,平衡资源利用率与响应速度。 4. **JIT编译器优化**:利用-XX:CompileThreshold等参数优化即时编译性能。 5. **监控与诊断工
|
2月前
|
存储 监控 Java
JVM进阶调优系列(8)如何手把手,逐行教她看懂GC日志?| IT男的专属浪漫
本文介绍了如何通过JVM参数打印GC日志,并通过示例代码展示了频繁YGC和FGC的场景。文章首先讲解了常见的GC日志参数,如`-XX:+PrintGCDetails`、`-XX:+PrintGCDateStamps`等,然后通过具体的JVM参数和代码示例,模拟了不同内存分配情况下的GC行为。最后,详细解析了GC日志的内容,帮助读者理解GC的执行过程和GC处理机制。

热门文章

最新文章