Java 内存 关系_JVM和Linux之间的详细内存关系

JVM和Linux之间的详细内存关系

在一些具有8g物理内存的服务器上,主要运行Java服务。系统内存分配如下:Java服务的JVM堆大小设置为6g,监视过程大约需要600m,Linux本身使用大约800m。

从表面上看,物理记忆应该足够;但实际操作是会发生大量SWAP(表明物理内存不足),如下图所示。由于同时发生SWAP和GC会导致JVM严重卡住,我们不得不问:内存在哪里?

JVM和Linux之间的详细内存关系

JVM和Linux之间的详细内存关系

要分析此问题,了解JVM与操作系统之间的内存关系非常重要。下一步是对Linux和JVM之间的内存关系进行一些分析。

首先,Linux和进程内存模型

JVM作为Linux系统上的进程运行。了解Linux和进程之间的内存关系是理解JVM和Linux内存之间关系的基础。下图显示了硬件,系统和进程级别的内存之间的摘要关系。

JVM和Linux之间的详细内存关系

从硬件角度来看,Linux系统的内存空间由两部分组成:物理内存和SWAP(在磁盘上)。物理内存是Linux活动使用的主要内存区域;当物理内存不足时,Linux会将一些未使用的内存数据放入磁盘上的SWAP中,以释放更多可用内存空间;使用位于SWAP中的数据时,必须先将其交换回内存。有关JVM运行时区域的详细说明,我建议大家看一下。

从Linux系统来看,除了引导系统的BIN区域外,整个内存空间主要分为两部分:内核内存(Kernel space),用户内存(User space)。

内核内存是Linux本身使用的内存空间。它主要用于程序逻辑,例如程序调度,内存分配和连接硬件资源。

用户内存提供给每个进程的主空间,Linux为每个进程提供相同的虚拟内存空间;这使得这些过程彼此独立,并且不会相互干扰。实现方法是使用虚拟内存技术:为每个进程提供虚拟内存空间,仅在实际使用虚拟内存时分配物理内存。如下图所示,对于32位的Linux系统,0到3G的虚拟内存空间分配通常用作用户空间,3到4G的虚拟内存空间分配为内核空间; 64位系统的划分是类似的。 。

JVM和Linux之间的详细内存关系

从过程的角度来看,进程可以直接访问的用户存储器(虚拟存储空间)分为五个部分:代码区,数据区,堆区࿰

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值