OutOfMemoryError系列(6): Out of swap space?

简介: 这是本系列的第六篇文章, 相关文章列表:OutOfMemoryError系列(1): Java heap spaceOutOfMemoryError系列(2): GC overhead limit exceededOutOfMemoryError系列(3): Permgen spaceOutOfMemoryError系列(4): MetaspaceOutOfMemoryError系列(5): Unable to create new native threadJVM启动参数指定了最大内存限制。

这是本系列的第六篇文章, 相关文章列表:

JVM启动参数指定了最大内存限制。如 -Xmx 以及相关的其他启动参数. 假若JVM使用的内存总量超过可用的物理内存, 操作系统就会用到虚拟内存。

java.lang.outofmemoryerror swap

错误信息 java.lang.OutOfMemoryError: Out of swap space? 表明, 交换空间(swap space,虚拟内存) 不足,是由于物理内存和交换空间都不足所以导致内存分配失败。

原因分析

如果 native heap 内存耗尽, 内存分配时, JVM 就会抛出 java.lang.OutOfmemoryError: Out of swap space? 错误消息, 这个消息告诉用户, 请求分配内存的操作失败了。

Java进程使用了虚拟内存才会发生这个错误。 对 Java的垃圾收集 来说这是很难应付的场景。即使现代的 GC算法 很先进, 但虚拟内存交换引发的系统延迟, 会让 GC暂停时间 膨胀到令人难以容忍的地步。

通常是操作系统层面的原因导致 java.lang.OutOfMemoryError: Out of swap space? 问题, 例如:

  • 操作系统的交换空间太小。
  • 机器上的某个进程耗光了所有的内存资源。

当然也可能是应用程序的本地内存泄漏(native leak)引起的, 例如, 某个程序/库不断地申请本地内存,却不进行释放。

解决方案

这个问题有多种解决办法。

第一种, 也是最简单的方法, 增加虚拟内存(swap space) 的大小. 各操作系统的设置方法不太一样, 比如Linux,可以使用下面的命令设置:

swapoff -a
dd if=/dev/zero of=swapfile bs=1024 count=655360
mkswap swapfile
swapon swapfile

其中创建了一个大小为 640MB 的 swapfile(交换文件) 并启用该文件。

因为垃圾收集器需要清理整个内存空间, 所以虚拟内存对 Java GC 来说是难以忍受的。存在内存交换时, 执行 垃圾收集暂停时间 会增加上百倍,甚至更多, 所以最好不要增加虚拟内存。

如果程序允许环境还受到 “坏邻居效应” 的干扰, 那么JVM还要和其他程序竞争计算资源, 提高性能的办法就是单独部署到专用的服务器/虚拟机中。

大多数时候, 我们唯一能做的就是升级服务器配置, 增加物理机的内存。当然也可以进行程序优化, 降低内存空间的使用量, 通过堆转储分析器可以检测到哪些方法/代码分配了大量的内存。

原文链接: https://plumbr.eu/outofmemoryerror/out-of-swap-space

翻译日期: 2017年9月27日

翻译人员: 铁锚: http://blog.csdn.net/renfufei

目录
相关文章
|
3天前
|
Java Linux
8 种 Java- 内存溢出六 -Out of swap space?
8 种 Java- 内存溢出六 -Out of swap space?
|
3天前
|
编译器 程序员 API
【踩坑记录】解决GCC 中C++ 17 的 std::filesystem 链接报错:undefined reference to `std::filesystem::path
【踩坑记录】解决GCC 中C++ 17 的 std::filesystem 链接报错:undefined reference to `std::filesystem::path
85 4
|
10月前
|
安全 Java 程序员
38-Metaspace区域是如何因为类太多而发生内存溢出的?
永久代溢出,由于到了JDK8,已经完全废弃了永久代的概念,改用与JRockit、J9一样在本地内存中实现的元空间(Metaspace)来代替,因此后续我们不再说 方法区、永久代,直接使用Metspace元空间来称呼。
495 0
38-Metaspace区域是如何因为类太多而发生内存溢出的?
|
11月前
|
Java 流计算
taskmanager.memory.jvm-metaspace.size
taskmanager.memory.jvm-metaspace.size
215 2
|
11月前
|
存储 缓存 算法
JVM虚拟机:内存区域详解(Eden Space、Survivor Space、Old Gen、Code Cache和Perm Gen)
JVM虚拟机:内存区域详解(Eden Space、Survivor Space、Old Gen、Code Cache和Perm Gen)
439 0
C++那些事儿 —— 名字空间(三分钟带你了解using namespace std到底是个啥?)
C++那些事儿 —— 名字空间(三分钟带你了解using namespace std到底是个啥?)
212 0
|
Kubernetes 容器
k8s 删除命令空间namespace卡住解决方法
k8s 删除命令空间namespace卡住解决方法
|
应用服务中间件 nginx
no space left on device磁盘空间不足
no space left on device磁盘空间不足
275 0
|
jenkins 持续交付 Docker
Jenkins - Free Swap Space 0
Jenkins - Free Swap Space 0
468 0
|
算法 安全
内存分配管理之Largeobjectspace
内存分配管理之Largeobjectspace
100 0