Spring Boot程序的JVM参数设置格式(Tomcat启动直接加在bin目录下catalina.sh文件里):
java ‐Xms2048M ‐Xmx2048M ‐Xmn1024M ‐Xss512K ‐XX: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:启用NUMA(Non-Uniform Memory Access)支持,优化多核CPU的内存访问。
其他参数
-XX:MetaspaceSize 和 -XX:MaxMetaspaceSize:分别设置Metaspace的初始和最大大小。Metaspace是Java 8及更高版本中元空间(PermGen)的替代品,用于存放类的元数据。-XX:MaxDirectMemorySize:设置直接内存的最大大小。直接内存主要用于NIO操作。
性能监控和调试参数
-XX:+PrintGCDetails:打印详细的垃圾回收日志,用于调试和性能分析。-XX:+PrintGCDateStamps:在垃圾回收日志中添加时间戳。-XX:+HeapDumpOnOutOfMemoryError:当发生OutOfMemoryError时,生成堆转储(dump)文件。
压缩指针参数(适用于64位JVM)
-XX:-UseCompressedOops:禁用压缩指针,用于某些需要精确地址计算的应用。
这些参数可以根据应用程序的需求和性能要求进行调整,但请注意,不恰当的配置可能导致应用程序性能下降或出现错误。在生产环境中更改JVM参数之前,建议进行充分的测试。