Java堆空间,本机堆和内存问题
最近,我在和一个朋友讨论为什么Java进程使用的内存比启动Java进程时设置的最大堆多。
代码创建的所有Java对象都是在Java堆空间内创建的,其大小由-Xmx选项定义。 但是一个Java进程由很多空间组成,而不仅仅是Java堆空间。 以下是组成Java进程的一些空格:
- 加载的库(包括jar和class文件)
- Java堆的控制结构
- 线程栈
- 生成的(JITed)代码
- 用户本机内存(在JNI中分配)
- … 更多…
在32位体系结构系统中,总进程大小不能超过4GB。 因此,一个32位的Java进程由许多空间(Java堆,本机内存(C-Heap)和其他空间)组成,并且其分配的空间不能超过4GB。
假设在32位生产系统上长时间运行具有-Xmx 1.5 GB(Java堆设置为1.5 GB)的Java应用程序服务器,并且已部署了许多应用程序。 一段时间后,客户希望在同一应用程序服务器上部署更多应用程序。 系统运营商了解,由于服务器将不得不处理更多的请求,因此还需要创建更多的对象并进行更多的处理。 因此,作为将来的解决方案,运营商决定将Java进程的最大堆增加到2 GB。
好的,这看起来是个好方法,但是实际上在此生产应用程序服务器上发生了什么? (这是真实情况)。 应用程序服务器因OutOfMemoryError崩溃! 您能考虑一下可能的原因吗?
我的第一个想法是2 GB的内存不足以支持所有这些应用程序。 不幸的是,问题出在别的地方。 您现在怎么看? 我会帮你一点。
java.lang.OutOfMemoryError: requested 55106896 bytes for Chunk::new.
真正的原因是,对于本机(C-Heap)内存,需要已部署的(旧)应用程序太大。 在操作员增加堆大小(从1.5GB到2 GB)之前,他们没有监视旧应用程序所需的本机内存空间。 此操作的副作用是自动将Java进程本机内存的可用最大大小从2.5 GB减小到2GB。 由于旧的应用程序已经使用了如此大的本机内存,因此此更改会使服务器崩溃 !!!
在这种情况下,唯一可以接受的解决方案是避免增加最大堆大小,部署新应用程序并减少吞吐量。 这不是一个完美的解决方案,但这是在这种情况下唯一可行的解决方案(因为我们的Java进程必须为32位)。
特别是在32位系统中,在增加Java堆大小之前,请注意Java进程本机内存的所需大小。 如果您处于这两个空间冲突的情况,那么解决方案可能并非如此简单。 如果您不能更改代码来克服这种情况,那么最常见的解决方案是移至最大进程大小限制太大的64位系统。
有四件事要记住:
- 进程大小的最大限制
- Java进程的大小不仅由Java堆组成
- 无法明确配置Java进程的本机(C-Heap)内存的大小,因为Java堆空间可以实现
- 应用程序所需的Java堆空间和本机(C堆)内存空间的大小仅由应用程序定义,并且这两个空间之间没有任何标准比率
参考:来自 Java的JCG合作伙伴 Adrianos Dadis的Java堆空间,本机堆和内存问题 ,集成和源博客的优点 。
翻译自: https://www.javacodegeeks.com/2013/01/java-heap-space-native-heap-and-memory-problems.html
Java堆空间,本机堆和内存问题相关推荐
- java中的堆空间增加_Java堆内存的10个要点
当我开始学习Java编程时,我不知道什么是堆内存或堆空间,我甚至不知道当对象创建时,它们被放在了哪里.当我开始正式写一些程序后,我会经常遇到java.lang.outOfMemoryError的报错, ...
- Unity 内存优化之理解托管堆和本机堆
https://docs.unity3d.com/Manual/BestPracticeUnderstandingPerformanceInUnity4-1.html https://www.dazh ...
- java堆空间(内存)
当Java程序开始运行时,JVM会从操作系统获取一些内存.JVM使用这些内存,这些内存的一部分就是堆内存.堆内存通常在存储地址的底层,向上排列.当一个对象通过new关键字或通过其他方式创建后,对象从堆 ...
- Java JVM堆空间的概述
Java JVM堆空间的概述 1.设置堆空间初始值和最大值 2.堆的核心概述 内存细分 3.堆空间大小的设置 4.新生代与老年代 5.图解对象分配的过程 6.常用调优工具 7.Minor GC.Maj ...
- java虚拟机堆空间
堆是一个进程唯一的,是内存管理的核心区域 jvm启动时 堆 就会被创建,大小也就确定了,是jvm中管理的最大的一块内存,堆的大小是可以调节的 <java虚拟机规范>规定,堆可以处于物理上不 ...
- OOM系列之一:java.lang.OutOfMemoryError: Java堆空间问题详解
第一篇:java.lang.OutOfMemoryError: Java heap space Java 应用程序只允许使用有限的内存量.此限制是在应用程序启动期间指定的.为了让事情变得更复杂,Jav ...
- 栈空间和堆空间的区别
栈空间用于存储函数参数和局部变量,所需空间由系统自动分配,回收也由系统管理,无需人工干预:堆空间用于存储动态分配的内存块,分配和释放空间均由程序员控制,有可能产生内存泄漏. 栈空间作为一个严格后进先出 ...
- Java的垃圾回机机制(见过讲得最清楚的)
原文请见:https://mp.weixin.qq.com/s/wn_7qve6OCD0SpYILvcKtg 读者朋友,你好,我是 wingjay. 垃圾回收机制是 Java 非常重要的特性之一,也是 ...
- java堆内存和堆外内存_Java堆空间,本机堆和内存问题
java堆内存和堆外内存 最近,我正在和一个朋友讨论为什么Java进程使用的内存比启动Java进程时设置的最大堆多. 代码创建的所有Java对象都是在Java堆空间内创建的,其大小由-Xmx选项定义. ...
最新文章
- 最近想做个音乐共享的软件
- 初创公司为什么要我_在一家大型初创公司担任副总裁之前,我希望知道什么
- cocos2d-x android 黑屏,cocos2d-x-3.8生成android 的apk后真机测试出现黑屏
- 深度学习新星:GANs的基本原理、应用和走向
- php的文件路径问题
- JavaOne 2015 –又一年,又向前迈进了一步
- Selenium自动化测试-5.脚本录制神器Katalon Recorder
- 由中缀式转化为后缀式
- HDMI热插拔检测原理
- 极客大学架构师训练营 数据结构与算法 分布式数据库 Hadoop 第八次作业
- 开源项目9GAG源码解析与Material改造(二)
- 轻取帝国CMS管理员密码
- ResNet网络 残差块的作用
- 這是一位女生寫的 - 男生如何追求女生
- Crash: ‘SQLiteDatabaseCorruptException: file is encrypted or is not a database‘的分析与解决
- iMazing怎么恢复备份?iMazing恢复备份教程分享
- amcharts教程
- 直播疑难杂症排查(7)— 黑屏、花屏、闪屏问题
- 教师招聘计算机面试技能测试,教师招聘面试中技能测试指什么
- JavaScript判断浏览器内核