【JVM】JVM 调优的参数都有哪些?

文章目录

    • [1. 设置堆空间大小](#1. 设置堆空间大小)
    • [2. 虚拟机栈的设置](#2. 虚拟机栈的设置)
    • [3. 年轻代中Eden区和两个Survivor区的大小比例](#3. 年轻代中Eden区和两个Survivor区的大小比例)
    • [4. 年轻代晋升老年代阈值](#4. 年轻代晋升老年代阈值)
    • [5. 设置垃圾回收收集器](#5. 设置垃圾回收收集器)

1. 设置堆空间大小

设置堆的初始大小和最大大小,为了防止垃圾收集器在初始大小、最大大小之间收缩堆而产生额外的时间,通常把最大、初始大小设置为相同的值


堆空间设置多少合适?

最大大小的默认值是物理内存的1/4,初始大小是物理内存的1/64
堆太小,可能会频繁的导致年轻代和老年代的垃圾回收,会产生stw,暂停用户线程
堆内存大肯定是好的,存在风险,假如发生了fullgc,它会扫描整个堆空间,暂停用户线程的时间长
设置参考推荐:尽量大,也要考察一下当前计算机其他程序的内存使用情况

2. 虚拟机栈的设置

虚拟机栈的设置:每个线程默认会开启1M的内存,用于存放栈帧、调用参数、局部变量等,但一般256K就够用。通常减少每个线程的堆栈,可以产生更多的线程,但这实际上还受限于操作系统。

3. 年轻代中Eden区和两个Survivor区的大小比例

设置年轻代中Eden区和两个Survivor区的大小比例。该值如果不设置,则默认比例为8:1:1。通过增大Eden区的大小,来减少YGC发生的次数,但有时我们发现,虽然次数减少了,但Eden区满的时候,由于占用的空间较大,导致释放缓慢,此时STW的时间较长,因此需要按照程序情况去调优。

4. 年轻代晋升老年代阈值

5. 设置垃圾回收收集器

相关推荐
__土块__14 分钟前
大厂后端一面模拟:从线程安全到分布式缓存的连环追问
jvm·redis·mysql·spring·java面试·concurrenthashmap·大厂后端
fly spider9 小时前
一文概括 JVM 核心内容
jvm
brahmsjiang9 小时前
Java类加载机制解析:从JVM启动到双亲委派,再到Android的特殊实现
android·java·jvm
cch89189 小时前
C++、Python与汇编语言终极对比
java·开发语言·jvm
zshs0009 小时前
从 HashMap 到基因法:同一套位运算思想,如何从 JVM 走到分布式数据库
jvm·数据库·分布式
彧翎Pro18 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
minji...1 天前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
woai33641 天前
JVM学习-基础篇-常见引用
jvm·学习
それども1 天前
理解JVM参数 Xss 线程的栈大小
jvm
玛卡巴卡ldf1 天前
【Springboot6】内存泄漏OOM、VisualVM、Arthas、Prometheus Grafana监控、垃圾回收
java·jvm·springboot