首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JVM常用内存参数配置

Server端JVM最好将-Xms和-Xmx设为相同值,避免每次垃圾回收完成后JVM重新分配内存;开发测试机JVM可以保留默认值。...JVM启动参数共分为三类:   1、标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容。...2、非标准参数(-X),默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,且不保证向后兼容。...本文将注重介绍JVM、GC的一些重要参数的设置来提高系统的性能。 JVM内存组成及GC相关内容请见之前的文章:JVM内存组成 GC策略&内存申请。JVM参数的含义实例见实例分析如下: ?   ...每个参数的调整都需要经过详细的性能测试,才能找到特定应用的最佳配置

3.9K30

JVM参数配置 java内存区域

5.JVM栈(JVM Stacks),与程序计数器一样,Java虚拟机栈(Java Virtual Machine Stacks)也是线程私有的,它的生命周期与线程相同。...JVM参数配置 JVM启动模式   Client模式:启动速度较快,但运行时性能和内存管理效率不高   Server模式:启动比Client模式慢10%,但运行时性能和内存管理效率较高   在JVM...”) ;     –使用复制算法;     –适合CPU等硬件一般的场合;     –到JDK1.7为止,是JVM Client模式下默认的新生代收集器;   2)设置参数:  -XX:+UseSerialGC...-Xms3550m:设置JVM促使内存为3550m。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。 -Xmn2g:设置年轻代大小为2G。...tomcat设置JVM参数 在Windows下,在$TOMCAT_HOME/bin/catalina.bat,Linux下,在$TOMCAT_HOME/bin/catalina.sh的前面,增加如下设置

1.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    内存泄露、内存溢出和堆外内存JVM优化参数配置参数

    造成内存泄漏典型场景: 1.单例模式的不正确使用 单例对象在初始化后将在JVM的整个生命周期中以静态变量的方式存在。...堆外内存 关于堆内内存以及相应的内存回收策略,在之前的文章《JVM内存管理和垃圾回收》、《JVM垃圾回收器、内存分配与回收策略》中已有介绍。...对于堆外内存是指分配的对象直接受操作系统管理的JVM内存堆以外的空间。同时因为这部分区域直接受操作系统的管理,别的进程可以直接通过操作系统对其进行访问,减少了从JVM中复制数据的过程。...,读写操作频繁的场景 但也存在如下缺点: 容易出现内存泄漏,并且很难排查 堆外内存的数据结构不直观,当存储结构复杂的对象时,会浪费大量的时间对其进行串行化 常用JVM配置参数 -Xms:JVM初始最小堆内存...-Xmx:JVM允许最大堆内存 -XX:PermSize:JVM初始非堆内存 -XX:MaxPermSize:JVM允许最大的非堆内存 -XX:+UseConcMarkSweepGC:年老代激活CMS

    1.4K10

    JAVA 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

    3.8K20

    JVM常用参数配置

    本文涉及:gc、堆、栈、永久区、元数据区的常用参数 GC基本参数 打印gc简要信息:-XX:+PrintGC [GC (System.gc()) 198247K->197248K(261632K),...1056768K class space used 308K, capacity 386K, committed 512K, reserved 1048576K 上方结果描述: 第2行:新生代总内存和已用内存...第3、4、5行:新生代各个区总内存和已用内存,这里eden:from:to的比例为8:1:1 第6行:老年代总内存和已用内存 指定gc日志的位置: -Xloggc:D:\appLog\app.log...堆最大值: -Xmx20m 堆的最小值: -Xms5m 获取系统堆内存信息 System.out.println("堆最大空间:" + Runtime.getRuntime().maxMemory(...1024 + "M");System.out.println("可用空间:" + Runtime.getRuntime().totalMemory() / 1024 / 1024 + "M"); 新生代的内存

    1K41

    一定要记住的14个JVM内存配置参数

    jvm setting的参数确实比较多(Oracle官网Java HotSpot VM Options),但是作为一名java开发者,那几个最常用最基本的参数设置和意义一定要死记和理解。...下面给出14个最常用和最基本的内存配置参数。...内存模型结构,这里不详细叙述,我用一张图来让你过目不忘(jvisualvm visualGC插件,下图并非以上jvm参数设置,只是为了方便对jvm内存模型记忆)。...一个重要的概念就是我们常常所说的设置jvm内存参数大多关注的是堆内存的大小,你可以简单理解成这样:堆内存 = Old + Eden + S0 + S1 ;年轻的 = Eden(新生代) + S0 +...以上就是14个参数,为了深刻理解,建议本地配置让后观察内存大小变化(可以使用jmap -heap pid 或者 visualGC来帮助观察)验证自己的理解是否正确。

    18.5K42

    2.3 JVM内存参数设置

    我们可以对运行时数据区的内存进行参数设置. 这是jvm调优的重点. 参数的变化将影响到整体效率 ?...这里单独说一下spring boot项目启动的时候如何设置jvm参数?...方法区(元空间)参数设置 ? 在jdk8之前有各区域叫做永久代, 在jdk8及以后改名字了, 叫做元空间. 这块内存空间占用的是直接的物理内存....比如内存条是8G的, 堆和栈分配了4G的空间, 那么元空间最多可以使用4G 我们可以通过参数来设置使用的最大内存 -XX:MetaspaceSize=256M     元空间的初始空间大小, 以字节位单位...由于调整元空间的大小需要full GC, 这是非常昂贵的操作, 如果应用在启动的时候发生大量的full GC, 通常都是由于永久代或元空间发生了大小的调整, 基于这种情况, 一般建议在JVM参数中将-

    2.9K21

    JVM参数配置&&命令工具

    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

    1K10

    JVM 内存区域大小参数设置

    需要提前了解的知识点: JVM内存模型 JVM垃圾回收算法 下图是JVM内存区域划分的逻辑图 JVM内存区域逻辑图 从图中我们大概了解JVM相关的内存区域。...Generation(持久代) Stack(栈区) Metaspace(元空间) Direct ByteBuffer(直接内存) 下面我们就通过一些JVM启动参数配置以上内存空间 Heap(堆)内存大小设置...-Xms512m 设置JVM堆初始内存为512M -Xmx1g 设置JVM堆最大可用内存为1G New Generation(新生代)内存大小设置 -Xmn256m 设置JVM的新生代内存大小...Old Generation(老年的)的内存大小设置 堆内存减去新生代内存 如上面设置的参数举例如下: 老年代初始内存为:512M-256M=256M 老年代最大内存为:1G-256M=768M...默认情况下,类元数据分配受到可用的本机内存容量的限制(容量依然取决于你使用32位JVM还是64位操作系统的虚拟内存的可用性)。 一个新的参数 (MaxMetaspaceSize)可以使用。

    4.8K150

    JVM 内存区域大小参数设置

    jmeter工具使用系列 jmeter基础内容在线公开课 jmeter性能测试在线公开课 接口自动化课程 性能测试课程 性能测试常见面试题 性能测试技能树JVM内存包括区域 Heap(堆区)   ...) 通过JVM启动参数配置以上内存空间   Heap(堆)内存大小设置   -Xms512m 设置JVM堆初始内存为512M   -Xmx1g 设置JVM堆最大可用内存为1G...New Generation(新生代)内存大小设置   -Xmn256m 设置JVM的新生代内存大小(-Xmn 是将NewSize与MaxNewSize设为一致。...256m),同下面两个参数   -XX:NewSize=256m   -XX:MaxNewSize=256m 通过新生代和老年代内存的比值来设置新生代大小   -XX:NewRatio...  堆内存减去新生代内存   如上面设置的参数举例如下:   老年代初始内存为:512M-256M=256M   老年代最大内存为:1G-256M=768M Stack

    8.9K21

    springboot 参数_bios内存启动参数配置

    文章目录 目的 测试代码 配置文件配置 获取自定义参数 项目打包发布 修改启动配置 方式一:系统变量 方式二:命令行参数 springboot启动参数解释 目的 1、熟悉springboot多环境配置...2、熟悉springboot使用jar包启动时候的参数含义 测试代码 配置文件配置 application.yml # springboot多环境配置 # springboot多环境配置 #端口,项目上下文...test' 注意以上两种方式的区别,我们可以在启动参数里修改我们配置文件中配置参数。...JVM系统变量 < 命令行参数(注意:优先级由低到高,非常多的启动命令中传参也是这个道理) springboot启动参数解释 测试配置的的参数如下: /usr/local/jdk/jdk1.8.0_261...设置此配置打开对年老代的压缩,即执行Full GC后对内存进行整理压缩,免得产生内存碎片,但有可能会影响性能。

    2.5K30

    【Tomcat】Tomcat配置JVM参数步骤

    这里向大家描述一下如何使用Tomcat配置JVM参数,Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机。...主要通过以下的几个jvm参数来设置堆内存的: -Xmx512m 最大总堆内存,一般设置为物理内存的1/4 -Xms512m 初始总堆内存,一般将它设置的和最大堆内存一样大,这样就不需要根据当前堆使用情况而调整堆的大小了...Tomcat配置JVM参数 Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机。...参数      描述 -Xms      JVM初始化堆的大小 -Xmx      JVM堆的最大值 这两个值的大小一般根据需要进行设置。初始化堆的大小执行了虚拟机在启动时向系统申请的内存的大小。...我的最终配置如下(系统8G内存),每天几百万pv一点问题都没有,网站没有停顿,2009年网站没有因为内存问题down过机。 ? $JAVA_ARGS.

    2.1K30

    JVM - 参数配置影响线程数

    一、题目相关参数 1.1 三个重要参数 -Xms 为 jvm 启动时分配 Heap初始内存(最小内存),比如 -Xms200m,表示分配200M -Xmx 为 jvm 运行过程中分配 Heap最大内存,...1.2 线程数的变动 准确来说,是 jvm 可生产线程数的数量,由三个方面影响: jvm 的堆内存大小 Thread 的 Stack内存大小 系统最大可创建的线程数量 增大堆内存(-Xms,-Xmx)会减少可创建的线程数量...;增大线程栈内存(-Xss,32 位系统中此参数值最小为 60 K)也会减少可创建的线程数量。...JDK5.0 以后,JVM会根据当前系统配置 吞吐量优先 的并行收集器 如上文所述,并行收集器主要以到达一定的吞吐量为目标,适用于科学技术和后台处理等。...JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此值。

    5.5K40

    jvm内存参数图解,Xmn,Xms,Xmx,XX

    Java中堆是JVM所管理的最大的一块内存空间,主要用于存放各种类的实例对象和数组,如下图所示: 在Java中,堆被划分成两个不同的区域:年轻代、老年代。...这样划分的目的是为了使JVM能够更好的管理堆内存中的对象,包括内存的分派以及回收。 堆是GC收集垃圾的主要区域。GC分为两种:Minor GC、Full GC。...1.年轻代 年轻代用来存放新近创建的对象,尺寸随堆大小的增加和减少而相应的变化,默认值是保持为堆的1/15.可以通过-Xmn参数设置年轻代为固定大小,也可以通过 -XX:NewRatio 来设置年轻代与年老代的大小比例...3.永久代 永久代是Hotspot虚拟机特有的概念,是方法区的一种实现,别的JVM都没有这个东西。在Java 8中,永久代被彻底移除,取而代之的是另一块与堆不相连的本地内存——元空间。...永久代或者“Perm Gen”包含了JVM需要的应用元数据,这些元数据描述了在应用里使用的类和方法。注意,永久代不是Java堆内存的一部分。永久代存放JVM运行时使用的类。

    1.5K20

    史上最全的JVM配置参数大全

    1、JVM参数配置 我们学习Java GC机制的目的是为了实用,也就是为了在JVM出现问题时分析原因并解决之,JVM监控与调优主要的着眼点在于如何配置、如何监控、如何优化3点上。...在Java虚拟机的参数中,有3种表示方法 标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容; 非标准参数(-X),默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,...在不同类型的JVM中,采用的参数有所不同 -Xmn 新生代内存大小,包括E区和两个S区的总和,使用方法如:-Xmn65535,-Xmn1024k,-Xmn512m,-Xmn1g (-Xms,-Xmx也是种写法...4、非Stable参数(非静态参数) 以-XX表示的非Stable参数JVM(Hotspot)中主要的参数可以大致分为3类 性能参数(Performance Options):用于JVM的性能调优和内存分配控制...,如初始化内存大小的设置; 行为参数(Behavioral Options):用于改变JVM的基础行为,如GC的方式和算法的选择; 调试参数(Debugging Options):用于监控、打印、输出等

    91910
    领券