为什么要优化?
- 运行的应用“卡住了”,日志不输出,程序没有反应
- 服务器的CPU负载突然升高
- 在多线程应用下,如何分配线程的数量?
- ...
JVM运行参数
jvm的参数类型分为三类,分别是:
- 标准参数
- -help
- -version ...
- -X参数 (非标准参数,可能新版本就会被替换掉)
- -Xint
- -Xcomp ...
- -XX参数(使用率较高)
- -XX:newSize
- -XX:+UseSerialGC ...
-X参数
[root@node01 test]# java ‐X
‐Xmixed 混合模式执行 (默认)
‐Xint 仅解释模式执行
‐Xbootclasspath:<用 : 分隔的目录和 zip/jar 文件>
设置搜索路径以引导类和资源
‐Xbootclasspath/a:<用 : 分隔的目录和 zip/jar 文件>
附加在引导类路径末尾
‐Xbootclasspath/p:<用 : 分隔的目录和 zip/jar 文件>
置于引导类路径之前
‐Xdiag 显示附加诊断消息
‐Xnoclassgc 禁用类垃圾收集
‐Xincgc 启用增量垃圾收集
‐Xloggc:<file> 将 GC 状态记录在文件中 (带时间戳)
‐Xbatch 禁用后台编译
‐Xms<size> 设置初始 Java 堆大小
‐Xmx<size> 设置最大 Java 堆大小
‐Xss<size> 设置 Java 线程堆栈大小
‐Xprof 输出 cpu 配置文件数据
‐Xfuture 启用最严格的检查, 预期将来的默认值
‐Xrs 减少 Java/VM 对操作系统信号的使用 (请参阅文档)
‐Xcheck:jni 对 JNI 函数执行其他检查
‐Xshare:off 不尝试使用共享类数据
‐Xshare:auto 在可能的情况下使用共享类数据 (默认)
‐Xshare:on 要求使用共享类数据, 否则将失败。
‐XshowSettings 显示所有设置并继续
‐XshowSettings:all
显示所有设置并继续
‐XshowSettings:vm 显示所有与 vm 相关的设置并继续
‐XshowSettings:properties
显示所有属性设置并继续
‐XshowSettings:locale
显示所有与区域设置相关的设置并继续
‐X 选项是非标准选项, 如有更改, 恕不另行通知。
-Xint、-Xcomp、-Xmixed
- 在解释模式(interpreted mode)下,
-Xint
标记会强制JVM执行所有的字节码,当然这
会降低运行速度,通常低10倍或更多. -
-Xcomp
参数与它(-Xint)正好相反,JVM在第一次使用时会把所有的字节码编译成
本地代码,从而带来最大程度的优化。- 然而,很多应用在使用-Xcomp也会有一些性能损失,当然这比使用-Xint损失的
少,原因是-xcomp没有让JVM启用JIT编译器的全部功能。JIT编译器可以对是否
需要编译做判断,如果所有代码都进行编译的话,对于一些只执行一次的代码就
没有意义了。
- 然而,很多应用在使用-Xcomp也会有一些性能损失,当然这比使用-Xint损失的
-
-Xmixed
是混合模式,将解释模式与编译模式进行混合使用,由jvm自己决定,这是
jvm默认的模式,也是推荐使用的模式。
-Xms与-Xmx参数
-
-Xms
与-Xmx
分别是设置jvm的堆内存的初始大小和最大大小。 -
-Xmx2048m
:等价于-XX:MaxHeapSize
,设置JVM最大堆内存为2048M。 -
-Xms512m
:等价于-XX:InitialHeapSize
,设置JVM初始堆内存为512M。
适当的调整jvm的内存大小,可以充分利用服务器资源,让程序跑的更快。
-XX:+PrintFlagsFinal
-XX:+PrintFlagsFinal
命令可以查看jvm默认的参数设置和修改了哪些参数.参数有boolean类型和数字类型,值的操作符是=或:=,分别代表默认值和被修改的值。
jinfo
如果想要查看正在运行的jvm就需要借助于jinfo命令查看。首先,启动一个tomcat用于测试,来观察下运行的jvm参数。
#查看所有的参数,用法:jinfo ‐flags <进程id>
#通过jps 或者 jps ‐l 查看java进程
[root@node01 bin]# jps
6346 Jps
6219 Bootstrap
[root@node01 bin]# jps ‐l
6358 sun.tools.jps.Jps
6219 org.apache.catalina.startup.Bootstrap
[root@node01 bin]#
[root@node01 bin]# jinfo ‐flags 6219
Attaching to process ID 6219, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.141‐b15
Non‐default VM flags: ‐XX:CICompilerCount=2 ‐XX:InitialHeapSize=31457280
‐XX:MaxHeapSize=488636416 ‐XX:MaxNewSize=162529280 ‐
XX:MinHeapDeltaBytes=524288 ‐XX:NewSize=10485760 ‐XX:OldSize=20971520 ‐
XX:+UseCompressedClassPointers ‐XX:+UseCompressedOops ‐
XX:+UseFastUnorderedTimeStamps ‐XX:+UseParallelGC
Command line: ‐Djava.util.logging.config.file=/tmp/apache‐tomcat‐
7.0.57/conf/logging.properties ‐
Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager ‐
Djava.endorsed.dirs=/tmp/apache‐tomcat‐7.0.57/endorsed ‐
Dcatalina.base=/tmp/apache‐tomcat‐7.0.57 ‐Dcatalina.home=/tmp/apache‐
tomcat‐7.0.57 ‐Djava.io.tmpdir=/tmp/apache‐tomcat‐7.0.57/temp
#查看某一参数的值,用法:jinfo ‐flag <参数名> <进程id>
[root@node01 bin]# jinfo ‐flag MaxHeapSize 6219
‐XX:MaxHeapSize=488636416
网友评论