最近,我在和一个朋友讨论为什么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堆空间,本机堆和内存问题相关推荐

  1. java中的堆空间增加_Java堆内存的10个要点

    当我开始学习Java编程时,我不知道什么是堆内存或堆空间,我甚至不知道当对象创建时,它们被放在了哪里.当我开始正式写一些程序后,我会经常遇到java.lang.outOfMemoryError的报错, ...

  2. Unity 内存优化之理解托管堆和本机堆

    https://docs.unity3d.com/Manual/BestPracticeUnderstandingPerformanceInUnity4-1.html https://www.dazh ...

  3. java堆空间(内存)

    当Java程序开始运行时,JVM会从操作系统获取一些内存.JVM使用这些内存,这些内存的一部分就是堆内存.堆内存通常在存储地址的底层,向上排列.当一个对象通过new关键字或通过其他方式创建后,对象从堆 ...

  4. Java JVM堆空间的概述

    Java JVM堆空间的概述 1.设置堆空间初始值和最大值 2.堆的核心概述 内存细分 3.堆空间大小的设置 4.新生代与老年代 5.图解对象分配的过程 6.常用调优工具 7.Minor GC.Maj ...

  5. java虚拟机堆空间

    堆是一个进程唯一的,是内存管理的核心区域 jvm启动时 堆 就会被创建,大小也就确定了,是jvm中管理的最大的一块内存,堆的大小是可以调节的 <java虚拟机规范>规定,堆可以处于物理上不 ...

  6. OOM系列之一:java.lang.OutOfMemoryError: Java堆空间问题详解

    第一篇:java.lang.OutOfMemoryError: Java heap space Java 应用程序只允许使用有限的内存量.此限制是在应用程序启动期间指定的.为了让事情变得更复杂,Jav ...

  7. 栈空间和堆空间的区别

    栈空间用于存储函数参数和局部变量,所需空间由系统自动分配,回收也由系统管理,无需人工干预:堆空间用于存储动态分配的内存块,分配和释放空间均由程序员控制,有可能产生内存泄漏. 栈空间作为一个严格后进先出 ...

  8. Java的垃圾回机机制(见过讲得最清楚的)

    原文请见:https://mp.weixin.qq.com/s/wn_7qve6OCD0SpYILvcKtg 读者朋友,你好,我是 wingjay. 垃圾回收机制是 Java 非常重要的特性之一,也是 ...

  9. java堆内存和堆外内存_Java堆空间,本机堆和内存问题

    java堆内存和堆外内存 最近,我正在和一个朋友讨论为什么Java进程使用的内存比启动Java进程时设置的最大堆多. 代码创建的所有Java对象都是在Java堆空间内创建的,其大小由-Xmx选项定义. ...

最新文章

  1. 最近想做个音乐共享的软件
  2. 初创公司为什么要我_在一家大型初创公司担任副总裁之前,我希望知道什么
  3. cocos2d-x android 黑屏,cocos2d-x-3.8生成android 的apk后真机测试出现黑屏
  4. 深度学习新星:GANs的基本原理、应用和走向
  5. php的文件路径问题
  6. JavaOne 2015 –又一年,又向前迈进了一步
  7. Selenium自动化测试-5.脚本录制神器Katalon Recorder
  8. 由中缀式转化为后缀式
  9. HDMI热插拔检测原理
  10. 极客大学架构师训练营 数据结构与算法 分布式数据库 Hadoop 第八次作业
  11. 开源项目9GAG源码解析与Material改造(二)
  12. 轻取帝国CMS管理员密码
  13. ResNet网络 残差块的作用
  14. 這是一位女生寫的 - 男生如何追求女生
  15. Crash: ‘SQLiteDatabaseCorruptException: file is encrypted or is not a database‘的分析与解决
  16. iMazing怎么恢复备份?iMazing恢复备份教程分享
  17. amcharts教程
  18. 直播疑难杂症排查(7)— 黑屏、花屏、闪屏问题
  19. 教师招聘计算机面试技能测试,教师招聘面试中技能测试指什么
  20. JavaScript判断浏览器内核

热门文章

  1. 快速排序算法思想及实现
  2. junit junit_穿越JUnit流
  3. java 反射 速度_Java反射,但速度更快
  4. activemq消息持久化_ActiveMQ 5.x中的消息持久性
  5. 属性拼接转换成字符串_使用一些可选的将字符串配置属性转换为其他类型
  6. jvm jstat_使用jstat报告自定义JVM指标集
  7. javabeans_(单元测试)JavaBeans的技巧
  8. 如何在不增加人员的情况下自动化API安全程序
  9. java ee基础知识_Java EE:基础知识
  10. Java生产监控的阴暗面