首页
学习
活动
专区
圈层
工具
发布

JVM堆大小的建议

JVM的堆大小设置是一趟很深的水,既要有对架构高度认识和落地,也要有对语言内部机制深入理解和掌握。...首先,需要对JVM的Heap大小有一个预设和监测,见这篇文章选择合适Java堆大小的五个建议(5 Tips for Proper Java Heap Size) https://dzone.com/articles...jivejdon设置的经验谈谈: 在生产环节,需要对年轻态和老生态两个区域大小进行监测,根据访问量不同和CMS设置不同,特别是老生态大小会经常变化,监测使用PSI-Probe。...初期JVM的大小按照年轻态:老生态=1:3进行配置,当然也和缓存中空闲失效期设置有关,缓存对其中对象如果空闲多长时间没有被使用,将实现清除,类似HttpSession机制。...这样,缓存失效期或者说缓存大小就需要根据JVM老生态在长时间生产环境运行下进行不断微调,Probe起到了关键作用,主要是其图形化直观显示,比起JDK的JConsole等等工具要方便。

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

    JVM 内存区域大小参数设置

    jmeter工具使用系列 jmeter基础内容在线公开课 jmeter性能测试在线公开课 接口自动化课程 性能测试课程 性能测试常见面试题 性能测试技能树JVM内存包括区域 Heap(堆区)   ...Permanent Generation(持久代)   Stack(栈区)   Metaspace(元空间)   Direct ByteBuffer(堆外内存) 通过JVM...启动参数来配置以上内存空间   Heap(堆)内存大小设置   -Xms512m 设置JVM堆初始内存为512M   -Xmx1g 设置JVM堆最大可用内存为1G New Generation...(新生代)内存大小设置   -Xmn256m 设置JVM的新生代内存大小(-Xmn 是将NewSize与MaxNewSize设为一致。...Eden区的比值为2:8,一个Survivor区占整个新生代的1/10 Eden内存大小设置 新生代减去2*Survivor的内存大小就是Eden的大小 Old Generation(老年的)的内存大小设置

    9.7K21

    JVM 内存区域大小参数设置

    需要提前了解的知识点: JVM内存模型 JVM垃圾回收算法 下图是JVM内存区域划分的逻辑图 JVM内存区域逻辑图 从图中我们大概了解JVM相关的内存区域。...Generation(持久代) Stack(栈区) Metaspace(元空间) Direct ByteBuffer(直接内存) 下面我们就通过一些JVM启动参数来配置以上内存空间 Heap(堆)内存大小设置...-Xms512m 设置JVM堆初始内存为512M -Xmx1g 设置JVM堆最大可用内存为1G New Generation(新生代)内存大小设置 -Xmn256m 设置JVM的新生代内存大小...2:8,一个Survivor区占整个新生代的1/10 Eden内存大小设置 新生代减去2*Survivor的内存大小就是Eden的大小。...Stack(栈)内存大小设置 -Xss1m 每个线程都会产生一个栈。

    5.6K150

    深入理解JVM:元空间大小详细解析

    前言 JVM加载类的时候,需要记录类的元数据,这些数据会保存在一个单独的内存区域内,在Java 7里,这个空间被称为永久代(Permgen),在Java 8里,使用元空间(Metaspace)代替了永久代...直到Java 8,永久代的改造才算完全搞定,在元空间中保存的数据比永久代中纯粹很多,就是类的元数据,这些信息只对编译期或JVM的运行时有用。...理论学习 使用Java 8以后,关于元空间的JVM参数有两个:-XX:MetaspaceSize=N和 -XX:MaxMetaspaceSize=N,对于64位JVM来说,元空间的默认初始大小是20.75MB...由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize

    3.3K00

    如何将JVM Docker镜像大小减少至少60%

    背景 如果您使用基于JVM的语言(Java、Kotlin、Scala等)已有一段时间,你可能已经注意到,从Java 11开始,Java运行时环境(JRE)不再有单独的发行版。...360MB,而实际应用程序Jar包大小约为26MB。...在我看来,整个Docker镜像的大小太大了,应用减小它,以便为每个将使用该Docker镜像的人节省空间和网络带宽。现在,让我们看看如何大幅减小Docker镜像的大小。...这意味着即使我们只想运行一个简单的基于JVM的应用程序,我们也必须安装整个JDK。这是由于Java 9中引入的模块化。...不幸的是,使用此类镜像会显着增加Docker镜像的大小。为了更好地理解这个问题,让我们看一下运行一个简单的基于JVM的应用程序所需的基本Dockerfile。

    2.3K31

    java虚拟机内存大小_jvm内存分布

    看着就是一个16字节的文件,看着像乱码,其实每个都是有对应的含义的,oracle官方是有专门的jvm字节码指令手册来查询每组指令对应的含义的。那我们研究的,当然不是这个。...那么一样的,这个jvm指令官方也是有手册可以查阅的,网上也有很多翻译版本,大家如果想了解可自行百度。 这里我只讲解本博文设计代码中的部分指令含义: 0....那么jvm虚拟机为什么要设置程序计数器这个结构呢?...由于HotSpot VM的自动内存管理系统要求对象起始地址必须是8字节的整数倍,换句话说,就是对象的大小必须是8字节的整数倍。...我们这里使用jdk自带的一个jvm调优工具jvisualvm来观察一下这个代码执行的的内存结构。

    1.4K30

    JVM系列之:String,数组和集合类的内存占用大小

    Instance size: 32 bytesSpace losses: 0 bytes internal + 1 bytes external = 1 bytes total 注意,本文的结论都在64位的JVM...可以看到数组对象的对象头大小是16字节,再加上数组里面的内容长度是15字节,再加上1位补全。最后得到的大小是32字节。 同样的,我们计算存有100个对象的数组,可以得到下面的结论: ?...注意最后面的Object数组,如果数组中存储的不是基础类型,那么实际上存储的是执行该对象的指针,该指针大小是4个字节。...再加上hash,coder,和hasIsZero属性,最后的大小是24字节。 我这里使用的是JDK14的String版本,不同的版本可能有所不同。...当然这只是这个String对象的大小,不包含底层数组的大小。 ? 我们来计算一下String对象的真实大小: String对象的大小+byte数组的大小=24+32=56字节。

    84810

    每天百万交易的支付系统,生产环境该怎么设置JVM堆内存大小

    好,那我们今天就结合实际案例来每日百万交易的支付系统,生产环境该怎么去设置JVM堆内存大小。...JVM堆内存。...03 支付系统每秒钟需要处理多少笔支付订单 要想合理设置我们JVM堆内存大小,我们就得去计算出我们系统每秒会处理多少笔支付单。...像我们这样的支付订单实体类大概也就20几个字段在几百个字节的样子,我们就算大一点就假设它500字节好了,不到1Kb 06 每秒发起的支付请求会占用多少内存 上面我们推算出来了每秒钟多少请求,同时推算了单个支付单的内存大小...总结,今天我带着大家来分析了一个系统开发完,我们该怎么去再生产环境配置我们的JVM堆内存大小,主要需要考虑我们应该部署多少台机器?每台机器要多少内存?每台机器每秒钟能有多少的请求过来并且生成对象?

    1.6K10

    【JVM 札记】浅谈 JVM

    JVM 是每个 Java 程序员必学的内容,毕竟 Java 运行在 JVM 之上。...在我们通过 java 执行一个 .class 文件时(比如 HelloWorld.class)文件时,就会启动一个 JVM,此时 JVM 是操作系统上的一个进程,当程序执行完成后,JVM 进行随之退出。...JVM 虽然是 Java 虚拟机,但是 JVM 是一个标准,通常我们说的 JVM 实际指的是 Oralce 的 HotSpot 实现。既然 JVM 是标准,那么就可以有多种实现。...又因为 JVM 是标准,我们可以理解为它对 .class 文件进行了标准化,那么无论是什么语言,只要编译后的能生成符合 JVM 标准的 .class 文件,就可以运行在 JVM 之上。...JVM 其实也是如此,比较常说的 JVM 的垃圾回收,不就是 JVM 对内存的管理方式么。

    50510

    JVM之JVM初探

    JVM初探 JVM 执行文件 类装入子系统 执行引擎 垃圾回收器 堆中的内存回收 方法区中的内存回收 关于回收的那些事 JVM 执行文件 JVM执行的文件为class文件,这个执行文件是什么意思呢,就是虚拟机能够识别的文件...,类加载器加载链接初始化后将数据保存在JVM运行时数据区中的文件。...类装入子系统 JVM的类加载器为ClassLoader采用双亲委派模型机制进行加载类。...即解释器先运行一段时间才能够真正提升效率); 垃圾回收器,Java能够流行的一个原因还有这个特点:他不用管理内存,由JVM的垃圾回收器自动进行回收垃圾,达到管理内存的目的。...垃圾回收器 JVM运行时内存结构为:PC程序计数器、本地方法栈、虚拟机栈、堆、方法区。

    68910

    JVM: JVM 内存划分

    如果你使用 Java 语言去开发,你就会发现大多数情况下你不用去关心无用对象的回收与内存的管理,因为这一切 JVM 虚拟机已经帮我们做好了。...了解 JVM 内存的各个区域将有助于我们深入了解它的管理机制,避免出现内存相关的问题和高效的解决问题。...它也是 JVM 垃圾回收作用的区域。...类和方法的信息等比较难确定大小,因此对于方法区大小的指定比较困难,太小容易出现方法区溢出,太大容易导致堆的空间不足。...对象所需的内存大小在类加载完毕后便可以确定了,为对象分配空间的任务相当于把一块确定大小的内存从 Java 堆中划分出来。 分配方式有指针碰撞和空闲列表两种。

    1.1K21

    字节大小

    sizeof(int)+sizeof(char)=5,但是考虑内存对齐,B的大小应 为8.对于类C,类的静态成员变量被放在全局区,和类的普通成员并没有放在一块。...所 以C的大小为sizeof(int)=4。D的大小为B+C的大小+自身数据成员的大小,一共为16....D)=12 对于class A,它含有一个虚函数,编译器会为虚函数生成一张虚函数表,来记录对应的函数地址,为此,在class A的内存地址中要有一个vfptr_A指针指向这个虚表,所以class A的大小为指针大小...(注意,无论类中有多少个虚函数,它们的大小都是4,因为内存中只需要保存这个指针即可)。...对于class C,它是vitual 继承A,所以要有一个指向父类A的指针,占有4字节大小aa()是继承自class A的虚函数,从结果来看,它没有在内存中占有空间,所以C的大小为sizeof(A)+4

    917100

    JVM初探 -JVM内存模型

    JVM是每个Java开发每天都会接触到的东西, 其相关知识也应该是每个人都要深入了解的. 但接触了很多人发现: 或了解片面或知识体系陈旧....因此最近抽时间研读了几本评价较高的JVM入门书籍, 算是总结于此....JVM 内存区域 JVM会将Java进程所管理的内存划分为若干不同的数据区域. 这些区域有各自的用途、创建/销毁时间: ? 一....1.8中, 永久区已经被彻底移除, 取而代之的是元数据区Metaspace(这一点在查看GC日志和使用jstat -gcutil查看GC情况时可以观察到),与永久代不同, 如果不指定Metaspace大小...显然, 本机直接内存的分配不会受到Java堆大小的限制(即不会遵守-Xms、-Xmx等设置), 但既然是内存, 则肯定还是会受到本机总内存大小及处理器寻址空间的限制, 因此动态扩展时也会出现OutOfMemoryError

    1.1K40

    jvm(1):jvm内存模型

    身为一个职业的Java程序员,每天打交到最多的就是jvm,那么套用孙子的一句话“知己知彼方能百战不殆”,熟悉jvm也就意味着是我们进阶路上必过之槛,下面先来张图,大概说明下jvm的内存分布 ?...域信息包括域名称、域类型和域修饰符、方法信息包括方法名称、返回类型、方法参数、方法修饰符、方法字节码、操作数栈和方法栈帧的局部变量区大小以及异常表。...Java堆:堆在JVM规范里是一种通用性的内存池,用于存放所有的Java对象。堆是一个运行时数据区,类的对象从中分配空间,堆的优势是可以动态地分配内存大小,生存周期也不需要事先告诉编译器。...由于Java虚拟机需要预先去生成相应的内存空间,所以但我们尝试运行程序的时候,Java虚拟机必须知道被存储在栈内的所有数据的确切大小和生命周期,以便按照上面陈述的分配存储方法通过上下移动堆栈指针来动态调整内存空间...栈的缺点是存储在栈里面的数据大小与生存期必须是确定的,从这一点来看,栈明显缺乏灵活性。

    99130
    领券