JVM 版本选择
即 java 的运行环境, 在满足项目需要的前提下, 尽量选用版本较高的 JVM, 一般来说高版本的稳定产品在速度和效率上比低版本会有改进
JVM 运行内存
xmx, xms 配置最小堆等于最大堆, 避免动态分配, 两者都调大一点,服务器开机后最大空闲内存-100m
应用程序用到最大内存的时候,JVM 先去做垃圾回收的动作, 释放被占用的一些内存
java -Xms64m -Xmx128m application.jar
tomcat_home/bin/catalina.sh
JAVA_OPTS='$JAVA_OPTS -server -Xmx800m -Xms512m -XX:MaxNewSize=256m -XX:MaxPermSize=256m -Djava.awt.headless=true'
-xms tomcat启动初始内存
-xmx tomcat 最大占用内存
JVM 参数分为 3 类
1.标准参数
- 开头,所有的 hotspot 都支持
java -version
java version "1.8.0_77"
# 查看标准参数
java -help
2.非标准参数
-X 开头,特定版本的 HotSpot 参数
# 查看非标准参数
java -X
-Xms<size> 设置初始 Java 堆大小
-Xmx<size> 设置最大 Java 堆大小
-Xss<size> 设置 Java 线程堆栈大小
3.不稳定参数
-XX 开头,下个版本可能取消
# 查看当前版本的不稳定参数
java -XX:+PrintCommandLineFlags
# 选项前面的 + 表示正在使用
# 选项前面的 - 表示未使用
-XX:InitialHeapSize=61818944
-XX:MaxHeapSize=989103104
-XX:+PrintCommandLineFlags
-XX:+UseCompressedClassPointers
-XX:+UseCompressedOops
-XX:+UseParallelGC
-XX:-UseG1GC
# 查看当前版本的不稳定参数的默认值
java -XX:+PrintFlagsInitial
bool UseTLAB = true
bool UseSerialGC = false
# 查看当前版本的不稳定参数最终生效的实际值
java -XX:+PrintFlagsFinal
InitialHeapSize := 62914560
InitialSurvi