JVM优化之优化常用参数和工具
内容提要
- jvm运行参数和参数设置
- jvm 内存模型
- 定位分析死锁和内存溢出
- 其他工具使用
为什么要优化JVM
1.生产环境需要承载更多的并发要求,对底层的优化能显著提升性能,节约成本
2.测试和生产环境的不同可能导致我们无法实时了解具体性能问题,我们需要借助对JVM了解分析问题所在。
jvm运行参数和参数设置
1.标准参数
由java -help检索出来的所有参数成为标准参数,未来发行版本中不会轻易修改,即使修改也会有官方通知
>java -help
-java [-options] class [args...] (执行类)或 java [-options] -jar jarfile [args...] #(执行 jar 文件)其中选项包括:
-D<名称>=<值> #设置系统属性
-version #输出产品版本并退出
-showversion # 输出产品版本并继续
-? -help 输出此帮助消息
-X #输出非标准选项的帮助
-d32 #使用 32 位数据模型 (如果可用)
-d64 #使用 64 位数据模型 (如果可用)
-server #选择 "server" VM 默认 VM 是 server,因为您是在服务器类计算机上运行。
-cp <目录和 zip/jar 文件的类搜索路径>
-classpath <目录和 zip/jar 文件的类搜索路径> #用 : 分隔的目录, JAR 档案和 ZIP 档案列表, 用于搜索类文件。
###########################以上为非常重要的参数 希望开发者一定要记住###########################
-verbose:[class|gc|jni] #启用详细输出
-version:<值> #警告: 此功能已过时, 将在未来发行版中删除。需要指定的版本才能运行
-jre-restrict-search | -no-jre-restrict-search #警告: 此功能已过时, 将在未来发行版中删除。在版本搜索中包括/排除用户专用 JRE
-ea[:<packagename>...|:<classname>]
-enableassertions[:<packagename>...|:<classname>]#按指定的粒度启用断言
-da[:<packagename>...|:<classname>]
-disableassertions[:<packagename>...|:<classname>] #禁用具有指定粒度的断言
-esa | -enablesystemassertions # 启用系统断言
-dsa | -disablesystemassertions # 禁用系统断言
-agentlib:<libname>[=<选项>] #加载本机代理库 <libname>, 例如 -agentlib:hprof另请参阅 -agentlib:jdwp=help 和 -agentlib:hprof=help
-agentpath:<pathname>[=<选项>] #按完整路径名加载本机代理库
-javaagent:<jarpath>[=<选项>] #加载 Java 编程语言代理, 请参阅 java.lang.instrument
-splash:<imagepath> # 使用指定的图像显示启动屏幕
使用Java代码测试系统属性
Properties properties = System.getProperties();
for (Map.Entry<Object, Object> objectObjectEntry : properties.entrySet()) {
System.out.printf("system prop : %s = %s\n",objectObjectEntry.getKey(),objectObjectEntry.getValue());
}
// java -Dmyname=huyiyu [类名] 之后在打印所有系统参数中找到myname=huyiyu
server和client参数
server: 显式指定-server时设置,或者64位系统时设置,使用 parNew GC 1 启动慢运行快
client:显式指定-client时设置,或者64位系统时设置,使用default GC2启动快运行慢
系统信息如下:
windowsX86 | 其他X86 | 其他X86 Mem:>2GB >2CPU | X64 |
---|---|---|---|
client | client | server | server |
2.非标准参数
-Xmixed # 混合模式执行 (默认)
-Xint #仅解释模式执行
-Xbatch #禁用后台编译
-Xms<size> #设置初始 Java 堆大小
-Xmx<size> #设置最大 Java 堆大小
-Xss<size> #设置 Java 线程堆栈大小
-XshowSettings #显示所有设置并继续
########################以上参数非常重要需要记住###############################
-XshowSettings:all#显示所有设置并继续
-XshowSettings:vm 显示所有与 vm 相关的设置并继续
-XshowSettings:properties #显示所有属性设置并继续
-XshowSettings:locale#显示所有与区域设置相关的设置并继续
-Xbootclasspath: <用 : 分隔的目录和 zip/jar 文件> #设置搜索路径以引导类和资源
-Xbootclasspath/a:<用 : 分隔的目录和 zip/jar 文件>#附加在引导类路径末尾
-Xbootclasspath/p:<用 : 分隔的目录和 zip/jar 文件>#置于引导类路径之前
-Xdiag #显示附加诊断消息
-Xnoclassgc #禁用类垃圾收集
-Xincgc #启用增量垃圾收集
-Xloggc:<file> #将 GC 状态记录在文件中 (带时间戳)
-Xprof #输出 cpu 配置文件数据
-Xfuture #启用最严格的检查, 预期将来的默认值
-Xrs #减少 Java/VM 对操作系统信号的使用 (请参阅文档)
-Xcheck:jni #对 JNI 函数执行其他检查
-Xshare:off #不尝试使用共享类数据
-Xshare:auto #在可能的情况下使用共享类数据 (默认)
-Xshare:on #要求使用共享类数据, 否则将失败。
#-X 选项是非标准选项, 如有更改, 恕不另行通知。
设置编译模式
类型 | 说明 | 示例 | 用法 | 备注 |
---|---|---|---|---|
int | 解释模式 | -Xint | -Xint | 强制运行字节码,效率低 |
comp | 编译模式 | -Xcomp | -Xcomp | 编译成native代码带来大程度的优化 |
mix | 混合模式 | -Xmix | -Xmix | 解释和编译混合进行,由jvm决定使用任意推荐使用 |
设置初始堆内存
类型 | 说明 | 示例 | 用法 | 备注 |
---|---|---|---|---|
Xms | 最小堆内存 | -Xms<数字><单位> | -Xmx1024m | 设置最小堆内存为1024MB |
Xmx | 最大堆内存 | -Xmx<数字><单位> | -Xms1024m | 设置最大堆内存为1024MB |
Xss | 初始堆内存 | -Xmx<数字><单位> | -Xss1024m | 设置初始堆内存为1024MB |
XX参数
XX参数也是非标准参数,用于jvm调优和debug操作,设置JVM有两种模式分别如下
类型 | 用法 | 示例 | 备注 |
---|---|---|---|
boolean | -XX:+/-<name> | XX:+DisableExplicitGC | +:启用 -:禁用 |
非boolean | :-XX:<name>=<value> | :-XX:NewRatio=1 |
# XX参数实战
-XX:+PrintFlagsFinal -version
# =表示默认参数 :=表示重置生效参数
bool UseXMMForArrayCopy = true {
product} {
default}
bool UseXMMForObjInit = false {
ARCH product} {
default}
bool UseXmmI2D = false {
ARCH product} {
default}
bool UseXmmI2F = false {
ARCH product} {
default}
bool UseXmmLoadAndClearUpper = true {
ARCH product} {
default}
bool UseXmmRegToRegMoveAll = true {
ARCH product}<