参数解释: -Xms: 初始堆大小 -Xmx: 最大堆大小 -Xmn: 年轻代大小 -XX:+PrintGCDetails 打印gc日志详情 -XX:SurvivorRatio=8 eden与survivor
本文涉及:gc、堆、栈、永久区、元数据区的常用参数 GC基本参数 打印gc简要信息:-XX:+PrintGC [GC (System.gc()) 198247K->197248K(261632K),
-Xms:初始堆大小 -Xmx:最大堆大小 -XX:NewSize=n:设置年轻代初始大小 -XX:MaxNewSize=n设置年轻代最大大小 -Xmn:相当于...
JVM参数配置 大致方向:JVM调优的目的是保证在一定吞吐量的情况下尽可能的减少GC次数,从而减少系统停顿时间,提高服务质量和效率。...默认物理内存的1/64 推荐:通常会将 -Xmx 与 -Xms两个参数配置成相同的值 public class Main { /** *堆内存大小配置 * -Xmx4000m...整个JVM内存大小=年轻代大小 + 年老代大小 + 持久代大小。持久代一般固定大小为64m,所以增大年轻代后,将会减小年老代大小。 此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。...路径 -q : 只输出LVMID -m : 输出JVM启动时传递给main()的参数 -v : 输出JVM启动时显示指定的JVM参数 ?...-flag : 输出指定args参数的值 -flags : 不需要args参数,输出所有JVM参数的值 -sysprops : 输出系统属性,等同于System.getProperties() jstat
JVM启动参数共分为三类: 1、标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容。...2、非标准参数(-X),默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,且不保证向后兼容。...本文将注重介绍JVM、GC的一些重要参数的设置来提高系统的性能。 JVM内存组成及GC相关内容请见之前的文章:JVM内存组成 GC策略&内存申请。JVM参数的含义实例见实例分析如下: ? ...每个参数的调整都需要经过详细的性能测试,才能找到特定应用的最佳配置。 ...具体操作上,32位Linux和64位Linux好像不一样,64位系统似乎只要配置MaxTenuringThreshold参数,CMS还是有暂停。
最近在看《深入理解Java虚拟机》一书,上面有好多例子都需要设置JVM的一些参数信息,再次记录下来,以后备用!!...//常见配置汇总 //堆设置 -Xms:初始堆大小 -Xmx:最大堆大小 -XX:NewSize=n:设置年轻代大小 -XX:NewRatio=n:设置年轻代和年老代的比值.如:为3,表示年轻代与年老代比值为
5.JVM栈(JVM Stacks),与程序计数器一样,Java虚拟机栈(Java Virtual Machine Stacks)也是线程私有的,它的生命周期与线程相同。...JVM参数配置 JVM启动模式 Client模式:启动速度较快,但运行时性能和内存管理效率不高 Server模式:启动比Client模式慢10%,但运行时性能和内存管理效率较高 在JVM...-Xms3550m:设置JVM促使内存为3550m。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。 -Xmn2g:设置年轻代大小为2G。...此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。 -Xss128k:设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。...tomcat设置JVM参数 在Windows下,在$TOMCAT_HOME/bin/catalina.bat,Linux下,在$TOMCAT_HOME/bin/catalina.sh的前面,增加如下设置
JVM参数分类 jvm 参数可分为三类: 标准参数:以 “-“ 开头的参数 非标准参数:以 “-X“ 开头的参数 不稳定参数:以”-XX“ 开头的参数 标准参数 标准参数是指在各个JVM版本中基本保持不变...JVM参数配置说明 调优栈内存 堆大小典型配置参数 -Xmx:设置最大堆大小。 -Xmx3550m,设置JVM最大可用内存为3550 MB。 -Xms:设置JVM初始内存。...说明:JDK 5.0以上版本,JVM根据系统配置自行设置,无需再设置此值。...JVM内存配置最佳实践 当设置的JVM堆空间过小时,程序会出现系统内存不足OOM(Out of Memory)的问题。...应用程序出现OOM问题时,会触发Linux内核的OOM Killer机制。该机制能够监控占用过大内存,尤其是瞬间消耗大量内存的进程,然后它会强制关闭某项进程以腾出内存留给系统,避免系统立刻崩溃。
这里向大家描述一下如何使用Tomcat配置JVM参数,Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机。...Tomcat配置JVM参数 Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机。...如下表所示有两个参数用来设置虚拟机使用内存的大小。 参数 描述 -Xms JVM初始化堆的大小 -Xmx JVM堆的最大值 这两个值的大小一般根据需要进行设置。...1:建议用64位操作系统,Linux下64位的jdk比32位jdk要慢一些,但是吃得内存更多,吞吐量更大。...JVM的Heap分配可以使用-X参数设定, JVM有2个GC线程。 第一个线程负责回收Heap的Young区。 第二个线程在Heap不足时,遍历Heap,将Young区升级为Older区。
一、题目相关参数 1.1 三个重要参数 -Xms 为 jvm 启动时分配 Heap初始内存(最小内存),比如 -Xms200m,表示分配200M -Xmx 为 jvm 运行过程中分配 Heap最大内存,...如果添加了 -Xmx 参数,将以这个参数后面的值为准,例如 java-cp you_classpath-Xmx512myour_class,那么最大内存就是 51210241024 字节。...JDK5.0 以后,JVM会根据当前系统配置 吞吐量优先 的并行收集器 如上文所述,并行收集器主要以到达一定的吞吐量为目标,适用于科学技术和后台处理等。...此配置仅对年轻代有效。即上述配置下,年轻代使用并发收集,而年老代仍旧使用串行收集。-XX:ParallelGCThreads=20 # 配置并行收集器的线程数,即:同时多少个线程一起进行垃圾回收。...JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此值。
JVM常用参数 关于-XX:+printGCDetails 作用:输出详细GC收集日志信息(当配置了-XX:+printGCDetails,控制台就会打印GC收集信息) GC: 详细...SurvivorRatio=4 一>Eden:S0:S1 =4:1:1 survivorRatio值就是设置eden区的比例占多少,s0/s1相同 -XX:SurivorRatio -XX NewRatio 配置年轻代与老年代在堆结构的占比
1、JVM参数配置 我们学习Java GC机制的目的是为了实用,也就是为了在JVM出现问题时分析原因并解决之,JVM监控与调优主要的着眼点在于如何配置、如何监控、如何优化3点上。...在Java虚拟机的参数中,有3种表示方法 标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容; 非标准参数(-X),默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,...3、非标准参数 非标准参数,是在标准参数的基础上进行扩展的参数,输入“java -X”命令,能够获得当前JVM支持的所有非标准参数列表(你会发现,其实并不多哦)。...4、非Stable参数(非静态参数) 以-XX表示的非Stable参数, JVM(Hotspot)中主要的参数可以大致分为3类 性能参数(Performance Options):用于JVM的性能调优和内存分配控制...jvm参数,用于显示jvm更加详细的信息; 对于非Stable参数,使用方法有4种: -XX:+ 启用选项 -XX:- 不启用选项 -XX:=<number
JVM 中最重要的一部分就是堆空间了,基本上大多数的线上 JVM 问题都是因为堆空间造成的 OutOfMemoryError。因此掌握 JVM 关于堆空间的参数配置对于排查线上问题非常重要。...tips:本文所有配置,如无特别说明,均基于JDK1.8。 堆配置 我们使用 -Xms 设置堆的初始空间大小,使用 -Xmx 设置堆的最大空间大小。...JVM 提供了参数 -Xmn 来设置年轻代内存的大小,但没有提供参数设置老年代的大小。但其实老年代的大小就等于堆大小减去年轻代大小。...如果要设置这部分的大小,那么就使用 -XX:SurvivorRatio 这个参数,该参数设置 eden / from 空间的比例关系,该参数的公式如下: -XX:SurvivorRatio = eden...直接内存 在 JVM 中还有一块内存,它独立于 JVM 的堆内存,它就是:直接内存。我们可以使用 -XX:MaxDirectMemorySize 设置最大直接内存。
相信掌握了这些参数之后,对于大家线上打印 GC 日志是有不少帮助的。 为了能够更直观地显示出每个参数的作用,我们将以下面的 Demo 为例子去设置 GC 日志参数。...为了认为制造 GC,我们启动时的 JVM 参数固定加上下面几个参数: -XX:+UseSerialGC -Xms20M -Xmx20M -Xmn10M -XX:SurvivorRatio=8 -XX:+...下面就让我们来看看油管 GC 的参数有哪些吧。 打印GC日志 在 GC 日志参数中,最简单的一个参数就是打印 GC 日志:-XX:PrintGC。...那么我们可以使用 PrintHeapAtGC 参数,该参数会在 GC 前后打印堆信息。...这个时间戳表示 JVM 启动后到现在所逝去的时间。
JVM常见内存参数配置简析 常见参数 -Xms 、-Xmx、-XX:newSize、-XX:MaxnewSize、-Xmn(-XX:newSize、-XX:MaxnewSize) 简析 1、...3)注意:jvm在执行GC时,会停止工作。...MaxnewSize的增大,可以降低GC频率, 一般来讲对于堆区的内存分配只需要对上述两个参数进行合理配置即可,但是如果想要进行更加精细的分配还可以对堆区内存进一步的细化,那就要用到下面的三个参数了-...两个参数的同时配置,也就是说如果通过-Xmn来配置新生代的内存大小,那么-XX:newSize = -XX:MaxnewSize = -Xmn,虽然会很方便,但需要注意的是这个参数是在JDK1.4版本以后才使用的...注意: 上面所述即为java虚拟机对外提供的可配置堆区的参数,接下来讲述java虚拟机对非堆区内存配置的两个参数: 1、-XX:PermSize:表示非堆区初始内存分配大小,其缩写为permanent
今天要说的是如何查看 JVM 中已经设置的参数,包括显示参数和隐式参数。 打印显式参数 -XX:+PrintVMOptions 该参数表示程序运行时,打印虚拟机接受到的命令行显式参数。...打印显式隐式参数 -XX:+PrintCommandLineFlags 该参数打印传递给虚拟机的显式和隐式参数。...打印所有系统参数 -XX:+PrintFlagsFinal 该参数会打印所有的系统参数的值。...我们用下面的命令运行程序: java -XX:+UseSerialGC -XX:+PrintFlagsFinal com.chenshuyi.ClassLoadDemo > jvm_flag_final.txt...之后打开 jvm_flag_final.txt 文件,可以看到有 800 多行,这是因为程序将虚拟机的所有参数都打印了出来。
java.lang.OutOfMemoryError:Java heap这个错误可以通过配置-Xms和-Xmx参数来设置。 3.-Xss:栈大小分配。...栈是每个线程私有的区域,通常只有几百K大小,决定了函数调用的深度,而局部变量、参数都分配到栈上。
-Xms128m:JVM初始分配的堆内存 -Xmx512m:JVM最大允许分配的堆内存,按需分配 -XX:PermSize=64M:JVM初始分配的非堆内存 -XX:MaxPermSize=128M:JVM...最大允许分配的非堆内存,按需分配 -XX:+HeapDumpOnOutOfMemoryError:参数表示当JVM发生OOM时,自动生成DUMP文件 -XX:+PrintGCDateStamps:输出GC...此配置仅对年轻代有效。可以同时并行多个垃圾收集线程 -XX:+UseParallelOldGC: 特殊说明: 解决问题的光鲜,藏着磕Bug的痛苦。 万物皆入轮回,谁也躲不掉!
JVM的参数类型 1. 标准参数 * -help * -server , -client * -version . -showversion * -cp , -classpath 2....X参数 * 非标准化参数(在各个JDK版本中可能会变,但是变动比较小) * -Xint : 解释执行 -Xcomp : 编译执行 第一次使用就编译成本地代码 -Xmixed :混合模式,...JVM自己来决定是否编译成本地代码 3....XX参数 非标转化参数 相对不稳定 主要用于JVM调优和Debug 参数分类 Boolean类型 格式:-XX:[+-] 表示启用或者禁用name属性。...不是X参数,而是XX参数 2. -Xms 等价于 -XX:InitialHeapSize 初始化的堆大小 3.
**jvm参数优化** * 最近碰到了公司项目发布设置参数较小导致项目启动失败(又背了一个锅) JAVA_OPTS="-Dproject.name=${key} -Djava.security.egd...此配置仅对年轻代有效。即上述配置下,年轻代使用并发收集,而年老代仍旧使用串行收集。
领取专属 10元无门槛券
手把手带您无忧上云