精华内容
下载资源
问答
  • 作者 |SimpleSmile_5177来源 |i7q.cn/50SRVt前言说一下 JVM 常用参数有哪些?是比较常用的面试问题,同时如果项目特别大了,需要增加一下堆内存的大小...

    作者 |  SimpleSmile_5177

    来源 | i7q.cn/50SRVt

    前言

    说一下 JVM 常用的参数有哪些?是比较常用的面试问题,同时如果项目特别大了,需要增加一下堆内存的大小、或者是系统老是莫明的挂掉,想查看下gc日志来排查一下错误的原因,都需要手动设置这些参数。

    各个参数介绍

    1.verbose:gc

    表示,启动jvm的时候,输出jvm里面的gc信息。格式如下:

    [Full GC 178K->99K(1984K), 0.0253877 secs]
    

    解读 :Full GC 就表示执行了一次Full GC的操作,178K 和99K 就表示执行GC前内存容量和执行GC后的内存容量。1984K就表示内存总容量。后面那个是执行本次GC所消耗的时间,单位是秒。

    2.-XX:+printGC

    这个打印的GC信息跟上个一样,就不做介绍了。

    3.-XX:+PrintGCDetails

    打印GC的详细信息。格式如下:

    –Heap
    – def new generation   total 13824K, used 11223K [0x27e80000, 0x28d80000, 0x28d80000)
    –  eden space 12288K,  91% used [0x27e80000, 0x28975f20, 0x28a80000)
    –  from space 1536K,   0% used [0x28a80000, 0x28a80000, 0x28c00000)
    –  to   space 1536K,   0% used [0x28c00000, 0x28c00000, 0x28d80000)
    – tenured generation   total 5120K, used 0K [0x28d80000, 0x29280000, 0x34680000)
    –   the space 5120K,   0% used [0x28d80000, 0x28d80000, 0x28d80200, 0x29280000)
    – compacting perm gen  total 12288K, used 142K [0x34680000, 0x35280000, 0x38680000)
    –   the space 12288K,   1% used [0x34680000, 0x346a3a90, 0x346a3c00, 0x35280000)
    –    ro space 10240K,  44% used [0x38680000, 0x38af73f0, 0x38af7400, 0x39080000)
    –    rw space 12288K,  52% used [0x39080000, 0x396cdd28, 0x396cde00, 0x39c80000)
    

    解读:new generation 就是堆内存里面的新生代。total的意思就是一共的,所以后面跟的就是新生代一共的内存大小。used也就是使用了多少内存大小。0x开头的那三个分别代表的是 底边界,当前边界,高边界。也就是新生代这片内存的起始点,当前使用到的地方和最大的内存地点。

    eden space 这个通常被翻译成伊甸园区,是在新生代里面的,一些创建的对象都会先被放进这里。后面那个12288K就表示伊甸园区一共的内存大小,91% used,很明显,表示已经使用了百分之多少。后面的那个0x跟上一行的解释一样。

    from space 和to space 是幸存者的两个区。也是属于新生代的。他两个区的大小必须是一样的。因为新生代的GC采用的是复制算法,每次只会用到一个幸存区,当一个幸存区满了的时候,把还是活的对象复制到另个幸存区,上个直接清空。这样做就不会产生内存碎片了。

    tenured generation 就表示老年代。

    compacting perm 表示永久代。由于这两个的格式跟前面我介绍的那个几乎一样,我就不必介绍了。

    4.-XX:+PrintGCTimeStamps

    打印GC发生的时间戳。格式如下:

    289.556: [GC [PSYoungGen: 314113K->15937K(300928K)] 405513K->107901K(407680K), 0.0178568 secs] [Times: user=0.06 sys=0.00, real=0.01 secs]
    
    293.271: [GC [PSYoungGen: 300865K->6577K(310720K)] 392829K->108873K(417472K), 0.0176464 secs] [Times: user=0.06 sys=0.00, real=0.01 secs]
    

    解读:289.556表示从jvm启动到发生垃圾回收所经历的的时间。GC表示这是新生代GC(Minor GC)。PSYoungGen表示新生代使用的是多线程垃圾回收器Parallel Scavenge。314113K->15937K(300928K)]这个跟上面那个GC格式一样,只不过,这个是表示的是新生代,幸存者区。后面那个是整个堆的大小,GC前和GC后的情况。Times这个显而易见,代表GC的所消耗的时间,用户垃圾回收的时间和系统消耗的时间和最终真实的消耗时间。

    5.-X:loggc:log/gc.log

    这个就表示,指定输出gc.log的文件位置。(我这里写的log/gc.log就表示在当前log的目录里,把GC日志写到叫gc.log的文件里。)

    6.-XX:+PrintHeapAtGC

    表示每次GC后,都打印堆的信息。(这个打印的基本格式跟上面第二条的基本类似,我也就不比多说了。)

    7.-XX:+TraceClassLoading

    监控类的加载。格式如下:

    •[Loaded java.lang.Object from shared objects file]
    •[Loaded java.io.Serializable from shared objects file]
    •[Loaded java.lang.Comparable from shared objects file]
    •[Loaded java.lang.CharSequence from shared objects file]
    •[Loaded java.lang.String from shared objects file]
    •[Loaded java.lang.reflect.GenericDeclaration from shared objects file]
    •[Loaded java.lang.reflect.Type from shared objects file]
    

    使用这个参数就能很清楚的看到那些类被加载的情况了。

    8.-XX:+PrintClassHistogram

    跟踪参数。这个按下Ctrl+Break后,就会打印一下信息:

    num     #instances         #bytes  class name
      
    ----------------------------------------------
      
       1:        890617      470266000  [B
      
       2:        890643       21375432  java.util.HashMap$Node
      
       3:        890608       14249728  java.lang.Long
      
       4:            13        8389712  [Ljava.util.HashMap$Node;
      
       5:          2062         371680  [C
      
       6:           463          41904  java.lang.Class
    

    –分别显示:序号、实例数量、总大小、类型。

    这里面那个类型,B和C的其实就是byte和char类型。

    9.-Xmx -Xms

    这个就表示设置堆内存的最大值和最小值。这个设置了最大值和最小值后,jvm启动后,并不会直接让堆内存就扩大到指定的最大数值。而是会先开辟指定的最小堆内存,如果经过数次GC后,还不能,满足程序的运行,才会逐渐的扩容堆的大小,但也不是直接扩大到最大内存。

    10.-Xmn

    设置新生代的内存大小。

    11.-XX:NewRatio

    新生代和老年代的比例。比如:1:4,就是新生代占五分之一。

    12.-XX:SurvivorRatio

    设置两个Survivor区和eden区的比例。比如:2:8 ,就是一个Survivor区占十分之一。

    13.-XX:+HeapDumpOnOutMemoryError

    发生OOM时,导出堆的信息到文件。

    14.-XX:+HeapDumpPath

    表示,导出堆信息的文件路径。

    15.-XX:OnOutOfMemoryError

    当系统产生OOM时,执行一个指定的脚本,这个脚本可以是任意功能的。比如生成当前线程的dump文件,或者是发送邮件和重启系统。

    16.-XX:PermSize -XX:MaxPermSize

    设置永久区的内存大小和最大值。永久区内存用光也会导致OOM的发生。

    17.-Xss

    设置栈的大小。栈都是每个线程独有一个,所有一般都是几百k的大小。

    近期热文

     

    【END】

    关注下方二维码,订阅更多精彩内容

    朕已阅 

    展开全文
  • 常用的JVM配置参数有哪些? -Xms:初始大小内存,默认为物理内存的1/64等价于-XX:InitialHeapSize -Xmx:最大分配内存,默认为物理内存的1/4等价于-XX:MaxHeapSize -Xss:设置单个线程栈的大小,一般默认为512k~...

    常用的JVM配置参数有哪些?

    • -Xms:初始大小内存,默认为物理内存的1/64等价于-XX:InitialHeapSize

    • -Xmx:最大分配内存,默认为物理内存的1/4等价于-XX:MaxHeapSize

    • -Xss:设置单个线程栈的大小,一般默认为512k~1024k等价于-XX:ThreadStackSize

      • 当值等于0的时候,代表使用得是默认大小
    • -Xmn:设置年轻代大小

    • -XX:MetaspaceSize:设置元空间大小(元空间与永久代最大的区别为:元空间并不在虚拟机中,而使用的是本地内存,因此,元空间只收本地内存的限制

      • 手动设置:-XX:MetaspaceSize=1024m
    • 典型设置案例

    • -XX:+PrintGCDetails:输出详细GC收集日志信息

    在这里插入图片描述

    在这里插入图片描述

    当堆内存不够的话,会爆出OOM错误

    在这里插入图片描述

    • -XX:SurvivorRatio:设置新生代中 eden 和 S0/S1 空间比例,默认 -XX:SurvivorRatio=8,Eden : S0 : S1 = 8 : 1 : 1

      ​ -XX:SurvivorRatio=4==》Eden : S0 : S1 = 4 : 1 : 1

    • -XX:NewRatio:配置年轻代和老年代在堆结构的占比,默认 -XX:NewRatio=2 新生代占1,老年代占2,年轻代占整个堆的 1/3

      ​ -XX:NewRatio=4 新生代占1,老年代占4,年轻代占整个堆的 1/5

    • -XX:MaxTenuringThreshold:设置垃圾最大年龄。默认是15

      -XX:MaxTenuringThreshold=0:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入老年代。对于老年代比较多的应用,可以提高效率。如果此值设置为一个较大的值,则年前对象会在Survivor区进行多次复制,这样可以增加对象在年轻代的存活时间,增加在年轻代被回收的概率!

    在这里插入图片描述

    因为是由四位二进制数组成,所以垃圾最大年龄为15.因为0-15是16个数字

    在这里插入图片描述

    展开全文
  • 常用参数 -Xms 初始化大小内存,默认为物理内存1/64 等价于-XX:InitialHeapSize -Xmx 最大分配内存,默认物理内存的1/4 等价于-XX:MaxHeapSize -Xss 设置单个线程栈的大小,一般默认为512K~1024K 等价于-XX:...

    基础知识

    在这里插入图片描述

    case

    在这里插入图片描述

    常用参数

    -Xms

    初始化大小内存,默认为物理内存1/64

    等价于-XX:InitialHeapSize

    -Xmx

    最大分配内存,默认物理内存的1/4

    等价于-XX:MaxHeapSize

    -Xss

    设置单个线程栈的大小,一般默认为512K~1024K

    等价于-XX:ThreadStackSize

    1. -XX:ThreadStackSize = 0 , 表示使用默认512K~1024K
    2. -XX:ThreadStackSize != 0 , 表示使用自己设置的

    -Xmn

    设置年轻代大小,一般不需要改动

    -Xms128m -Xmx4096m -Xss1024k -XX:MetaSpaceSize=512m -XX:+PrintCommandFlags -XX:+PrintGCDetails -XX:+UseSerialGC

    -XX:MetaspaceSize

    元空间的本质和永久代类似,都是对JVM规范中方法区的实现。

    不过元空间与永久代之间最大的区别在于:

    • 永久代在堆里面
    • 元空间并不在虚拟机中,而是使用本地内存。
      因此,在默认情况下,元空间的大小仅受本地内存限制

    eg:

    Xms10m -Xmx10m -XX:MetaspaceSize=1024m -XX:+PrintFlagsFinal

    初始值约21M,也就是说只占用本地内存的21M,如果你频繁的new对象,有可能就会把元空间撑爆从而发生元空间异常,因此需要调大一些

    -XX:+PrintGCDetails

    GC

    在这里插入图片描述

    FullGC

    在这里插入图片描述

    -XX:SurvivorRatio (了解)

    在这里插入图片描述

    在这里插入图片描述

    -XX:NewRatio (了解)

    在这里插入图片描述

    -XX:MaxTenuringThreshold (了解)

    设置垃圾的最大年龄

    在这里插入图片描述

    jvm典型配置案例

    -Xms128m -Xmx4096m -Xss1024k -XX:MetaspaceSize=512m -XX:+PrintCommandLineFlags -XX:+PrintGCDetails -XX:+UseSerialGC
    

    输出结果

    -XX:InitialHeapSize=134217728 
    -XX:MaxHeapSize=4294967296 
    -XX:MetaspaceSize=536870912 
    -XX:+PrintCommandLineFlags 
    -XX:+PrintGCDetails 
    -XX:ThreadStackSize=1024 
    -XX:+UseCompressedClassPointers 
    -XX:+UseCompressedOops 
    -XX:-UseLargePagesIndividualAllocation 
    -XX:+UseSerialGC 
    HelloGC
    Heap
     def new generation   total 39296K, used 2796K [0x00000006c0000000, 0x00000006c2aa0000, 0x0000000715550000)
      eden space 34944K,   8% used [0x00000006c0000000, 0x00000006c02bb048, 0x00000006c2220000)
      from space 4352K,   0% used [0x00000006c2220000, 0x00000006c2220000, 0x00000006c2660000)
      to   space 4352K,   0% used [0x00000006c2660000, 0x00000006c2660000, 0x00000006c2aa0000)
     tenured generation   total 87424K, used 0K [0x0000000715550000, 0x000000071aab0000, 0x00000007c0000000)
       the space 87424K,   0% used [0x0000000715550000, 0x0000000715550000, 0x0000000715550200, 0x000000071aab0000)
     Metaspace       used 3084K, capacity 4496K, committed 4864K, reserved 1056768K
      class space    used 335K, capacity 388K, committed 512K, reserved 1048576K
    
    • -XX:+UseSerialGC : 串行垃圾回收器
    • -XX:+UseParalleGC :并行垃圾回收器
    展开全文
  • ????基础知识 ... // 返回 Java 虚拟机中的内存总量 long maxMemory = Runtime.getRuntime().maxMemory(); // 返回 Java 虚拟机视图使用最大内存量 System.out.println("TOTAL_MEMORY(-Xms) ...

    🍀基础知识

    在这里插入图片描述

    long totalMemory = Runtime.getRuntime().totalMemory();  // 返回 Java 虚拟机中的内存总量
    long maxMemory = Runtime.getRuntime().maxMemory();  // 返回 Java 虚拟机视图使用的最大内存量
    System.out.println("TOTAL_MEMORY(-Xms) = " + totalMemory + "(字节)、" + (totalMemory / (double) 1024 * 1024) + "MB");
    System.out.println("MAX_MEMORY(-Xmx) = " + maxMemory + "(字节)、" + (maxMemory / (double) 1024 * 1024) + "MB");
    

    🍀常用参数

    📌 -Xms

    初始大小内存,默认为物理内存 1/64    等价于 -XX:InitialHeapSize

    📌 -Xmx

    最大分配内存,默认为物理内存 1/4    等价于 -XX:MaxHeapSize

    📌 -Xss

    设置单个线程栈的大小,一般默认为 512k~1024k    等价于 -XX:ThreadStackSize

    📌 -Xmn

    设置年轻代大小

    📌 -XX:MetaspaceSize

    设置元空间大小
    -Xms10m -Xmx10m -XX:MetaspaceSize=1024m -XX:+PrintFlagsFinal

    📌 典型设置案例

    -Xms128m -Xmx2048m -Xss1024k 
    -XX:MetaspaceSize=512m 
    -XX:+PrintCommandLineFlags 
    -XX:+PrintGCDetails 
    -XX:+UseSerialGC
    

    📌 -XX:+PrintGCDetails

    ⏳ 输出详细的 GC 收集日志信息
    ⏳ GC 信息解读

    在这里插入图片描述

    ⏳ FullGC 信息解读

    在这里插入图片描述

    📌 -XX:SurvivorRatio

    默认情况
    Eden:S0:S1 = 8:1:1
    -XX:+PrintGCDetails -XX:+UseSerialGC -Xms10m -Xmx10m -XX:SurvivorRatio=8
    在这里插入图片描述
    Eden:S0:S1 = 4:1:1
    -XX:+PrintGCDetails -XX:+UseSerialGC -Xms10m -Xmx10m -XX:SurvivorRatio=4
    在这里插入图片描述

    📌 -XX:NewRatio

    默认情况
    -Xms10m -Xmx10m -XX:+PrintGCDetails -XX:+UseSerialGC -XX:NewRatio=2
    在这里插入图片描述
    修改
    -Xms10m -Xmx10m -XX:+PrintGCDetails -XX:+UseSerialGC -XX:NewRatio=4
    在这里插入图片描述

    📌 -XX:MaxTenuringThreshold

    查看默认进入老年代年龄:
    在这里插入图片描述
    -XX:MaxTenuringThreshold=0:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过 Survivor 区,直接进入老年代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在 Survivor 区进行多次复制,这样可以增加对象在年轻代的存活时间,增加在年轻代即被回收的概率。

    ========================================================
    jinfo -flag MaxTenuringThreshold 15120

    jinfo -flag PrintGCDetails 15120

    展开全文
  • jvm常用参数: (1) -Xms。初始大小内存,默认为物理内存1/64。等价于 -XX:InitialHeapSize。 (2) -Xmx。最大分配内存,默认为物理内存1/4。等价于 -XX:MaxHeapSize。 (3) -Xss。设置单个线程大小,一般...
  • 最大分配内存,默认为物理内存的 1/4,等价于 -XX:MaxHeapSize 3、-Xss 设置单个线程栈的大小,一般默认为 512-1024k,等价于 -XX:ThreadStackSize 4、-Xmn 设置年轻代的大小 ...
  • 最大分配内存,默认为物理内存的 1/4 等价于 -XX:MaxHeapSize -Xss 设置单个线程栈的大小,一般默认为 512-1024k 等价于 -XX:ThreadStackSize -Xmn 设置年轻代的大小 整个JVM内存大小=年轻代大小...
  • 1、-Xms初始大小内存,默认为物理内存 1/64,等价于 -XX:InitialHeapSize2、-Xmx最大分配内存,默认为物理内存的 1/4,等价于 -XX:MaxHeapSize3、-Xss设置单个线程栈的大小,一般默认为 512-1024k,等价于 -XX:...
  • 例如:-Xms20m -Xmx20m -Xss256k jvm配置 XX比X稳定性更差,并且版本更新不会进行...(一般来说-Xms和-Xmx设置为相同大小,因为当heap自动扩容时,会发生内存抖动,影响程序稳定性) 3、-Xmn n为new,...
  • 内存设置 原理 JVM堆内存分为2块:Permanent Space 和 Heap Space。...Permanent 即 持久代(Permanent Generation),主要存放是Java类定义信息,与垃圾收集器要收集Java对象关系不大。 Heap = { Old +...
  • JVM常用基础参数-栈内存Xss讲解

    千次阅读 2019-06-28 10:15:55
    3、你平时工作中用过JVM常用基本配置参数有哪些? 4、强引用、软引用、弱引用、虚引用费别是什么? 5、请你谈谈对OOM认识 6、GC垃圾回收算法与垃圾收集器关系?分别是什么请你谈谈? ...
  • 内存设置 原理 ...JVM堆内存分为2块:Permanent Space 和 Heap Space。...Permanent 即 持久代(Permanent Generation),主要存放是Java类定义信息,与垃圾收集器要收集Java对象关系不大。Heap =
  • 各主要JVM启动参数的作用如下: -Xms:设置jvm内存的初始大小 -Xmx:设置jvm内存的最大值 -Xmn:设置新域的大小(这个似乎只对jdk1.4来说是有效的,后来就废弃了) -Xss:设置每个线程的堆栈大小(也就是说,在...
  • 常用的X参数 -Xms: 初始大小内存,默认为物理内存1/64,等价于-XX:InitialHeapSize -Xmx: 最大分配内存,默认物理内存1/4,等价于-XX:MaxHeapSize -Xss: 设置单个线程栈大小,默认542K~1024K ,等价于-XX:...
  • 比如我们启动数据库时候设定多大的内存,使用什么样隔离级别,日志文件大小,存放位置等等一系列东东。当然我们数据库系统启动后,有些系统变量(参数)也可以通过动态修改来及时调整数据库。这个系统变量在...
  • 本篇主要了解下面内容:1、JVM常用的配置参数如、内存配置...1、堆内存配置参数有时候我们需要根据GC情况实时情况,动态调整各个区域大小,所以会配置JVM内存各个区域的内存大小是我们经常会用到配置参数。...
  • 2、CMS、G1的常用个性化参数。3、常用的一些应用启动参数,在项目启动的时候我们需要配置哪些参数。4、各种部署场景下通过什么方式配置这些参数。1、堆内存配置参数 时候我们需要根据GC的情况实时情况,动态调整...
  • 我们在这一篇文章中已经大概了解到了jvm的参数有哪些,大概怎么设置。 JVM调优由浅到深(一)——jvm参数配置 现在我们再来详细得再更加详细分析一次; 常用参数设置 设置最大堆内存 参数说明 例子 最大堆...
  • 常用参数C.为什么要将永久代 (PermGen) 替换为元空间 (MetaSpace) 呢?6.运行时常量池7.直接内存二、HotSpot 虚拟机对象探秘1.对象创建2.对象的内存布局3.对象访问定位三、重点补充内容1.String 类和常量池2....
  • 常用的头文件如下 :#include //字符处理#include //定义错误码#include //浮点数处理#include //文件输入/输出#include //参数化输入/输出#include //数据流输入/输出#include //定义输入/输出函数#include //...
  • 一、你平时工作用过jvm常用基本配置参数有哪些?1、回顾堆内存初始大小jdk1.8之后将最初永久代取消了,由元空间取代。在jdk1.8中,永久已经被移除,被一个称为元空间区域取代。元空间本质和永久代类似。元空间...
  • 我也曾经遇到过监控操作系统cpu,内存和网卡发送接收速率等场景(使用snmp协议采集,也可以使用prometheus监控器去采集),今天那就一起总结一下常用的Linux系统参数获取方式,比如cpu核数,用户名,内存参数等等...
  • JVM内存结构

    2019-06-27 10:23:56
    3、你平时工作中用过JVM常用基本配置参数有哪些? 4、强引用、软引用、弱引用、虚引用费别是什么? 5、请你谈谈对OOM认识 6、GC垃圾回收算法与垃圾收集器关系?分别是什么请你谈谈? 7、 怎么查看服务器.....
  • 都是在内存的哪些区域溢出?垃圾收集有哪些原则?有哪些垃圾收集算法及其实现?新生代和老年代的回收策略如何?各种内存相关的JVM参数是什么意思?本文主要总结问题4、问题5和问题7.总体如下: 2.判断对象是否存活的...
  • Java堆内存初始大小

    千次阅读 2019-06-28 10:08:19
    3、你平时工作中用过JVM常用基本配置参数有哪些? 4、强引用、软引用、弱引用、虚引用费别是什么? 5、请你谈谈对OOM认识 6、GC垃圾回收算法与垃圾收集器关系?分别是什么请你谈谈? 7、 怎么查...
  • 2、有哪些常用内存优化手段与参数设置? 3、Redis持久化机制有哪些?如何设置? Redis常用的数据类型: 最为常用的数据类型有一下五种: *String *Hash *List *Set *Sorted set 在具体描述这几种数据类型之前,...
  • 匿名用户1级2016-01-25 回答mysql的优化大的两方面:1、配置优化配置的优化其实包含两个方面的:操作系统内核的...2)mysql配置的优化,一般来说包含:IO处理的常用参数、最大连接数设置、缓存使用参数的设置、慢...
  • 下面我将会列出我常用的监控内存的工具。 vmstat vmstat显示关于进程,内存,页,块I/O,traps和CPU的信息。vmstat既可以展示平均值,也可以是实时数据。通过提供采样频率和采样时间就可以开启vmstat的采样模式...

空空如也

空空如也

1 2 3 4 5 ... 18
收藏数 351
精华内容 140
关键字:

内存的常用参数有哪些