1、我们为什么要对jvm做优化?

  在本地开发环境中我们很少会遇到需要对jvm进行优化的需求,但是到了生产环境,我们可能将有下面的需求:
    运行的应用“卡住了”,日志不输出,程序没有反应
    服务器的CPU负载突然升高
    在多线程应用下,如何分配线程的数量?

2、jvm的运行参数

  在jvm中有很多的参数可以进行设置,这样可以让jvm在各种环境中都能够高效的运行。
  绝大部分的参数保持默认即可。

2.1 三种参数类型

  jvm的参数类型分为三类,分别是:
  标准参数
    -help
    -version
  -X参数 (非标准参数)
    -Xint
    -Xcomp
  -XX参数(使用率较高)
    -XX:newSize
    -XX:+UseSerialGC

2.2 标准参数

  jvm的标准参数,一般都是很稳定的,在未来的JVM版本中不会改变,可以使用java -help检索出所有的标准参数。
  

  2.2.1 查看jvm版本

    # ‐showversion参数是表示,先打印版本信息,再执行后面的命令,在调试时非常有用,后面会使用到。

    

  2.2.2 通过-D设置系统属性参数

public class TestJVM {
public static void main(String[] args) {
String str = System.getProperty("str");
if (str == null) {
System.out.println("jvmTest");
} else {
System.out.println(str);
}
}
}
  进行编译、测试:
#编译
javac JvmTest.java
#运行
java JvmTest
#修改str值为JVM
java -Dstr=JVM JvmTest
    

  2.2.3 -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类型。 
  测试:
  #由于机器是64位系统,所以不支持client模式
#-client
java -client -showversion JvmTest
#-server
java -server -showversion JvmTest
    

2.3 -X参数

  jvm的-X参数是非标准参数,在不同版本的jvm中,参数可能会有所不同,可以通过java -X查看非标准参数。

  

  2.3.1 -Xint、-Xcomp、-Xmixed

    在解释模式(interpreted mode)下,-Xint标记会强制JVM执行所有的字节码,当然这会降低运行速度,通常低10倍或更多。 

    -Xcomp参数与它(-Xint)正好相反,JVM在第一次使用时会把所有的字节码编译成本地代码,从而带来最大程度的优化。

      然而,很多应用在使用-Xcomp也会有一些性能损失,当然这比使用-Xint损失的少,原因是-xcomp没有让JVM启用JIT编译器的全部功能。JIT编译器可以对是否需要编译做判断,如果所有代码都进行编译的话,对于一些只执行一次的代码就没有意义了。
    -Xmixed是混合模式,将解释模式与编译模式进行混合使用,由jvm自己决定,这是jvm默认的模式,也是推荐使用的模式。 
  #注意:编译模式下,第一次执行会比解释模式下执行慢一些,注意观察。
#-Xint
java -showversion -Xint JvmTest
#-Xcomp
java -showversion -Xcomp JvmTest
#默认混合模式
java -showversion JvmTest

    

2.4 -XX参数

  -XX参数也是非标准参数,主要用于jvm的调优和debug操作。
  -XX参数的使用有种方式,一种是boolean类型,一种是非boolean类型:
  boolean类型
    格式:-XX:[+-]
    如:-XX:+DisableExplicitGC 表示禁用手动调用gc操作,也就是说调用System.gc()无效
  非boolean类型
    格式:-XX:
    如:-XX:NewRatio=1 表示新生代和老年代的比值

  测试:

java -showversion -XX:+DisableExplicitGC JvmTest

  

2.5 -Xms与-Xmx参数

  -Xms与-Xmx分别是设置jvm的堆内存的初始大小和最大大小。
  -Xmx2048m:等价于-XX:MaxHeapSize,设置JVM最大堆内存为2048M。
  -Xms512m:等价于-XX:InitialHeapSize,设置JVM初始堆内存为512M。
  适当的调整jvm的内存大小,可以充分利用服务器资源,让程序跑的更快。 

  测试:

java -Xms521m -Xmx1024m JvmTest

  

2.6 查看jvm的运行参数

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

  2.6.1 运行java命令时打印参数

     运行java命令时打印参数,需要添加java -XX:+PrintFlagsFinal -version参数即可。
   参数有boolean类型和数字类型,值的操作符是=:=,分别代表默认值被修改的值。 
    

    

  测试:

java -XX:+PrintFlagsFinal -XX:+VerifySharedSpaces -version

    

    

  2.6.2 查看正在运行的jvm参数

    如果想要查看正在运行的jvm就需要借助于jinfo命令查看。 
    首先,启动一个tomcat用于测试,来观察下运行的jvm参数

     #通过jps 或者 jps ‐l 查看java进程

#jps
jps
#jps -l
jps -l

      

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

jinfo -flags 29720

       

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

jinfo -flag MaxHeapSize 29720

       

jvm的运行参数的更多相关文章

  1. (转)用JMX监测JVM的运行参数

    翻译自http://java.sun.com/javase/6/docs/technotes/guides/management/agent.html  用JMX管理你的JVMJMX是Java管理扩展 ...

  2. IntelliJ IDEA设置JVM运行参数

    2015十一月 28 原 IntelliJ IDEA设置JVM运行参数 分类:JavaSE (11566) (1) 打开 IDEA 安装目录,看到有一个 bin 目录,其中有两个 vmoptions ...

  3. idea设置JVM运行参数

    对JVM运行参数进行修改是JVM性能调优的重要手段,下面介绍在应用程序开发过程中JVM参数设置的几种方式. 方式一 java程序运行时指定 -Dproperty=value 该参数通常用于设置系统级全 ...

  4. 【转】idea设置JVM运行参数

    对JVM运行参数进行修改是JVM性能调优的重要手段,下面介绍在应用程序开发过程中JVM参数设置的几种方式. 方式一 java程序运行时指定 -Dproperty=value 该参数通常用于设置系统级全 ...

  5. JVM 运行参数 & 代码监控

    1.Java代码监控 JDK提供java.lang.management包, 其实就是基于JMX技术规范,提供一套完整的MBean,动态获取JVM的运行时数据,达到监控JVM性能的目的. packag ...

  6. IntelliJ IDEA和Eclipse设置JVM运行参数

    打开 IDEA 安装目录,看到有一个 bin 目录,其中有两个 vmoptions 文件,需针对不同的JDK进行配置: 32 位:idea.exe.vmoptions64 位:idea64.exe.v ...

  7. JVM 内部运行线程介绍

    转(http://club.alibabatech.org/article_detail.htm?articleId=4) JVM 内部运行线程介绍 作者:蒋家佳/觉梦(支付宝开发工程师) 浏览量: ...

  8. JVM入门——运行时数据区

    这张图我相信基本上对JVM有点接触的都应该很熟悉,可以说这是JVM入门的第一课.其中的“堆”和“虚拟机栈(栈)”更是耳熟能详.下面将围绕这张图对JVM的运行时数据区做一个简单介绍. 程序计数器(Pro ...

  9. JVM常用启动参数

    本文参考 jvm参数设置大全:http://www.cnblogs.com/marcotan/p/4256885.html 堆内存分配及gc:http://www.cnblogs.com/weiguo ...

随机推荐

  1. Caffe Ubuntu14.04 + CUDA 8 (支持GTX1080 1070等Pascal架构显卡)

    1. 前言 本教程使用的系统是Ubuntu 14.04 LTS 64-bit,使用的CUDA版本为8. 理论上本教程支持Pascal架构显卡,如游戏卡GeForce GTX1070,GTX 1080, ...

  2. 爬虫笔记(十一)——认识cookie

    什么是cookie? 在爬虫的使用中,如果涉及登录等操作时,经常会使用到cookie.简单的来说,我们访问每一个互联网页面,都是通过HTTP协议进行的,而HTTP协议是一个无状态协议,所谓的无状态协议 ...

  3. script和scriptreplay_超骚气的实时监控你的服务器

    今天看到一个超级叼的linux命令,可以完整记录屏幕上的命令与输出结果. 有人问这有什么叼的,不就是保存历史操作记录吗?我看看日志也能看出来. 不不不,我要说的“完整记录”包括第几秒执行什么命令,就像 ...

  4. day39-进程-队列

    #队列Queue:进程之间数据是隔离的,不共享的,但是通过multiprocessing的Queue可以实现进程之间的通信. #1.先进先出:把1 2 3放到队列里,按1 2 3的顺序拿出来. fro ...

  5. 2. Unconstrained Optimization(2th)

    2.1 Basic Results on the Existence of Optimizers 2.1. DefinitionLet $f:U->\mathbb{R}$ be a functi ...

  6. Jmeter阶梯式压测

    https://www.cnblogs.com/Zfc-Cjk/p/11639219.html 什么是阶梯式压测? 阶梯式压测,就是对系统的压力呈现阶梯性增加的过程,每个阶段压力值都要增加一个数量值, ...

  7. IPC之——信号量集(多个信号量)

    如果两个进程不仅需要同步,还要保证先后执行顺序,就要用两个信号量(互斥锁)来解决 //栅栏模型:实现以下框架中的四个子进程 所有进程做完任务后 在一起执行下一次  #include <stdio ...

  8. asp.net 获取日期

    //获取日期+时间 DateTime.Now.ToString(); // 2008-9-4 20:02:10 DateTime.Now.ToLocalTime().ToString(); // 20 ...

  9. SQL数据库的查询方法

    简单查询: 一.投影 select * from 表名 select 列1,列2... from 表名 select distinct 列名 from 表名 二.筛选 select top 数字 列| ...

  10. C++语言堆栈的详细讲解

    本文主要向大家介绍了C++语言堆栈的详细讲解,通过具体的内容向大家展示,希望对大家学习C++语言有所帮助. 一.预备知识—程序的内存分配 一个由c/C++编译的程序占用的内存分为以下几个部分 1.栈区 ...