JVM之内存模型带参数

发布时间:2024年01月05日

在这里插入图片描述
Spring Boot程序的JVM参数设置格式(Tomcat启动直接加在bin目录下catalina.sh文件里):

 java ‐Xms2048MXmx2048MXmn1024MXss512KXX:MetaspaceSize=256M ‐XX:MaxMetaspaceSize=256M ‐jar xxxxxx.jar

-Xss:每个线程的栈大小
-Xms:设置堆的初始可用大小,默认物理内存的1/64
-Xmx:设置堆的最大可用大小,默认物理内存的1/4
-Xmn:新生代大小
-XX:NewRatio:默认2表示新生代占年老代的1/2,占整个堆内存的1/3。
-XX:SurvivorRatio:默认8表示一个survivor区占用1/8的Eden内存,即1/10的新生代内存。
关于元空间的JVM参数有两个:-XX:MetaspaceSize=N和 -XX:MaxMetaspaceSize=N
-XX:MaxMetaspaceSize: 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小。
-XX:MetaspaceSize: 指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M左右,达到该值就会触发full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。这个跟早期jdk版本的-XX:PermSize参数意思不一样,-XX:PermSize代表永久代的初始容量。
由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值,并设置得比初始值要大,对于8G物理内存的机器来说,一般我会将这两个值都设置为256M。


堆内存参数

-Xms:设置JVM初始堆大小。例如,-Xms512m表示初始堆大小为512MB-Xmx:设置JVM最大堆大小。例如,-Xmx1g表示最大堆大小为1GB-XX:NewSize-XX:MaxNewSize:分别设置新生代(Young Generation)的初始大小和最大大小。新生代是堆内存的一部分,主要用于存放新创建的对象。

-XX:SurvivorRatio:设置新生代中Eden区和Survivor区的比例。例如,设置为4意味着Eden区与Survivor区的大小比为4:1

垃圾回收参数

-XX:+UseConcMarkSweepGC:启用CMS垃圾回收器。

-XX:+UseParallelGC:启用并行垃圾回收器。

-XX:+UseG1GC:启用G1垃圾回收器。

-XX:+UseNUMA:启用NUMANon-Uniform Memory Access)支持,优化多核CPU的内存访问。

其他参数

-XX:MetaspaceSize-XX:MaxMetaspaceSize:分别设置Metaspace的初始和最大大小。MetaspaceJava 8及更高版本中元空间(PermGen)的替代品,用于存放类的元数据。

-XX:MaxDirectMemorySize:设置直接内存的最大大小。直接内存主要用于NIO操作。


性能监控和调试参数

-XX:+PrintGCDetails:打印详细的垃圾回收日志,用于调试和性能分析。

-XX:+PrintGCDateStamps:在垃圾回收日志中添加时间戳。

-XX:+HeapDumpOnOutOfMemoryError:当发生OutOfMemoryError时,生成堆转储(dump)文件。

压缩指针参数(适用于64位JVM)

-XX:-UseCompressedOops:禁用压缩指针,用于某些需要精确地址计算的应用。

这些参数可以根据应用程序的需求和性能要求进行调整,但请注意,不恰当的配置可能导致应用程序性能下降或出现错误。在生产环境中更改JVM参数之前,建议进行充分的测试。

文章来源:https://blog.csdn.net/weixin_44859605/article/details/135318846
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。