【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. 设置垃圾回收收集器

相关推荐
普通网友3 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python
那我掉的头发算什么8 小时前
【javaEE】多线程——线程安全进阶☆☆☆
java·jvm·安全·java-ee·intellij-idea
2501_941236219 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
2501_9411113410 小时前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
2501_9411115110 小时前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
2501_9411113310 小时前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
2501_9411113711 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
一只会写代码的猫11 小时前
深度解析 Java、C# 和 C++ 的内存管理机制:自动 vs 手动
java·jvm·算法
2501_9411113413 小时前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
2501_9411114021 小时前
使用Scrapy框架构建分布式爬虫
jvm·数据库·python