美文网首页
JVM优化篇之参数(一)

JVM优化篇之参数(一)

作者: 热心肠的徐同学 | 来源:发表于2019-06-12 23:09 被阅读0次

    为什么要优化?

    • 运行的应用“卡住了”,日志不输出,程序没有反应
    • 服务器的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编译器可以对是否
        需要编译做判断,如果所有代码都进行编译的话,对于一些只执行一次的代码就
        没有意义了。
    • -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
    

    相关文章

      网友评论

          本文标题:JVM优化篇之参数(一)

          本文链接:https://www.haomeiwen.com/subject/nvhdfctx.html