JVM调优的运行参数的使用和jvm监控

1.什么情况下要进行JVM优化

1.运行的应用“卡住了”,日志不输出,程序没有反应 

2.服务器的CPU负载突然升高 

3.多线程运行下如何分配线程数量,并不是线程分配的越多程序执行效率越高

而这些原因是否是因为频繁的FullGC造成的,造成FullGC的原因,一个是因为内存分配不够,二是频繁出现有大对象都会直接在老年代进行分配,所以需要通过一些运行参数去判断

2.JVM的运行参数

2.1JVM的三种参数

JVM的参数分为三种类型分别是:

  • 标准参数:

标准参数一般都是很稳定的,在JVM未来的版本中不会改变

            -help

            -version 

使用java -help检索出所有的标准参数

java -D的使用:

例如如下代码:

public class TestMain {

    public static void main(String[] args) {
        String test = System.getProperty("test");
        if (test == null) {
            System.out.println("test");
        } else {
            System.out.println(test);
        }
    }
}

编译后执行输出没有值,但使用命令行执行 java -Dtest=helloworld TestJvm将会输出123

-server与-client参数

可以通过-server或-client设置jvm的运行参数。
它们的区别是Server VM的初始堆空间会大一些,默认使用的是并行垃圾回收器,启动慢运行快。 Client VM相对来讲会保守一些,初始堆空间会小一些,使用串行的垃圾回收器,它的目标是为了让JVM的启 动速度更快,但运行速度会比Serverm模式慢些。 JVM在启动的时候会根据硬件和操作系统自动选择使用Server还是Client类型的JVM。
32位操作系统 如果是Windows系统,不论硬件配置如何,都默认使用Client类型的JVM。 如果是其他操作系统上,机器配置有2GB以上的内存同时有2个以上CPU的话默认使用server模式,否则 使用client模式。

64位操作系统 只有server类型,不支持client类型。

  • -X参数 (非标准参数)

            -Xint 

            -Xcomp 

jvm的-X参数是非标准参数,在不同版本的jvm中,参数可能会有所不同,可以通过java -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参数(使用率较高) 

-XX参数也是非标准参数,主要用于jvm的调优和debug操作。

-XX参数的使用有2种方式,一种是boolean类型,一种是非boolean类型

           -XX:newSize 

           -XX:+UseSerialGC

boolean类型

格式:-XX:[+/-]<name> 表示启用(“+”表示启用)或禁用(“-”表示禁用)<name>属性。 如:-XX:+DisableExplicitGC 表示禁用手动调用gc操作,也就是说调用System.gc()无效

非boolean类型 格式:-XX:<name>=<value> 表示<name>属性的值为<value> 。如:-XX:NewRatio=1 表示新生代和老年代的比值

查看jvm的运行参数

有些时候我们需要查看jvm的运行参数,这个需求可能会存在2种情况:
第一,运行java命令时打印出运行参数;

第二,查看正在运行的java进程的参数; 

运行java命令时打印参数:java -XX:+PrintFlagsFinal -version 

由上述的信息可以看出,参数有boolean类型和数字类型,值的操作符是=或:=,分别代表默认值和被修改的值。

2.2jstat命令进行查看堆内存使用情况

命令的格式如下:
jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数] 

  • 查看class加载统计

启动应用,使用jps命令查看启动应用的端口号。输入jstat -class [端口号]结果如下

其中

Loaded:加载class的数量

Bytes:所占用空间大小

Unloaded:未加载数量

Bytes:未加载占用空间

Time:加载所需时间 

  • 查看编译情况

命令:jstat -compiler [端口号] 

说明:
          Compiled:编译数量。

          Failed:失败数量

          Invalid:不可用数量

          Time:编译时间

          FailedType:失败类型

          FailedMethod:失败的方法 

  • 查看垃圾回收统计

命令:jstat -gc [端口号]

也可以指定打印的间隔和次数。

例如:每1秒中打印一次,共打印5次 。jstat -gc [端口号] 1000 10

S0C:第一个Survivor区的大小(KB)

S1C:第二个Survivor区的大小(KB)

S0U:第一个Survivor区的使用大小(KB)

S1U:第二个Survivor区的使用大小(KB)

EC:Eden区的大小(KB)

EU:Eden区的使用大小(KB)

OC:Old区大小(KB)

OU:Old使用大小(KB)

MC:方法区大小(KB)

MU:方法区使用大小(KB)

CCSC:压缩类空间大小(KB)

CCSU:压缩类空间使用大小(KB)

YGC:年轻代垃圾回收次数

YGCT:年轻代垃圾回收消耗时间

FGC:老年代垃圾回收次数

FGCT:老年代垃圾回收消耗时间

GCT:垃圾回收消耗总时间

3.查看正在运行的jvm参数 

如果想要查看正在运行的jvm就需要借助于jinfo命令查看。 
 
通过jps 或者  jps -l查看java进程 

目前启动了一个tomcat

查看所有的参数,用法:jinfo -flags <进程id> 

查看某一参数的值,用法:jinfo -flag <参数名> <进程id> 

3.Java VisualVm监控jvm

如果是本机直接运行JAVA_HOME\bin\目录下的jvisualvm.exe就可以了。

如果是远程linux服务器则需要修改配置

1.修改linux上jdk配置

服务器jdk安装路径为/usr/local/java/jdk1.8.0_181,然后进入jre/lib/management,将jmsremote.password.template复制一份并改名为jmxremote.password;

编辑jmxremote.password文件修改去掉 # monitorRole  QED 和 # controlRole  R&D 这两行前面的注释符号

2.修改启动命令

例如:

java  -Djava.rmi.server.hostname=192.168.xxx.xxx -Dcom.sun.management.jmxremote.port=9999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false  -jar ./test.jar

说明:

  • -Djava.rmi.server.hostname=192.168.xxx.xxx :远程服务器的主机名;  
  • -Dcom.sun.management.jmxremote.port =9999:是JMX远程监控端口号,需要在防火墙开放该端口;
  • -Dcom.sun.management.jmxremote.ssl=false :表示是否对连接开启SSL加密,默认开启;
  • -Dcom.sun.management.jmxremote.authenticate=false   :是否需要开启用户认证,默认开启,如果开启需要额外配置授权文件;

3.启动命令后,打开jvisualvm.exe

不使用SSL连接

结果如下:

也可以使用阿里的arthas来进行监控,官网地址https://alibaba.github.io/arthas

常用的 JVM 调优的参数

  • -Xms2g:初始化推大小为 2g;

  • -Xmx2g:堆最大内存为 2g;

  • -XX:NewRatio=4:设置年轻的和老年代的内存比例为 1:4; -XX:SurvivorRatio=8:设置新生代 Eden 和 Survivor 比例为 8:2; –XX:+UseParNewGC:指定使用 ParNew + Serial Old 垃圾回收器组合; -XX:+UseParallelOldGC:指定使用 ParNew + ParNew Old 垃圾回收器组合;

  • -XX:+UseConcMarkSweepGC:指定使用 CMS + Serial Old 垃圾回收器组合

  • -XX:+PrintGC:开启打印 gc 信息;

  • -XX:+PrintGCDetails:打印 gc 详细信息

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值