8 种 Java- 内存溢出之五 -Unable to create new native thread

简介: 8 种 Java- 内存溢出之五 -Unable to create new native thread

5.1 Unable to create new native thread

Java 应用一般是多线程的. 这意味着在用 Java 写的程序 (似乎) 可以在同时做多件事情. 例如 – 即使机器只有一个处理器 – 当你把内容从一个窗口拖动到另一个, 在后台播放的电影不会停止因为您一次执行了几个操作.

思考线程的一种方法是将它们视为可供提交任务的工作人员. 如果你只有一名员工, 他 / 她只能同时做一个任务. 但是当你有一打员工供你差遣, 他们可以同时完成你的几个要求.

现在, 就像在现实世界的员工, 在 JVM 里的线程也需要一些空间来开展他们被传唤去要处理的工作. 当线程数超过了这个内存空间的限制的时候, 我们就会碰到下边的问题:

这个消息:java.lang.OutOfMemoryError: Unable to create new native thread 意味着Java 应用已经达到它可以运行的线程数的上限.

5.2 原因

只要 JVM 向 OS 申请新线程, 你都有机会碰到 java.lang.OutOfMemoryError: Unable to create new native thread. 只要下面的 OS 不能再分配一个新的 native thread, 这个 OutOfMemoryError 会被抛出. 准确的 native thread 限制与对应的平台有关, 因此, 我们推荐通过运行下面的 例子 来找到这个限制. 但是, 通常, 引发 java.lang.OutOfMemoryError: Unable to create new native thread 会经过下列阶段:

  1. 运行在 JVM 里的一个应用请求一个新的 Java 线程
  2. JVM native 代码传递要创建一个新的 native 线程到 OS
  3. OS 尝试创建一个新的 native 线程, 同时需要分配内存给这个线程
  4. OS 将会拒绝本地内存分配, 可能是因为 32-bit Java 进程大小已经耗尽了它的内存地址区域 – 如: 达到了 2-4GB 的进程大小限制 – 或是这个 OS 的虚拟内存已经被耗尽
  5. 抛出 java.lang.OutOfMemoryError: Unable to create new native thread 错误.

5.3 示例

下列例子循环启动和创建新的线程. 当运行这段代码, 操作系统会迅速达到限制, 显示出 java.lang.OutOfMemoryError: Unable to create new native thread 消息.

while (true) {
    new Thread(new Runnable()) {
        public void run() {
            try {
                Thread.sleep(10000000);
            } catch (InterruptedException e) { }
        }
    }}.start();
}
JAVA

确切的 native thread 限制与平台有关, 如在 Windows, Linux 和 Mac OS X 上测试结果如下:

  • 64-bit Mac OS X 10.9, Java 1.7.0_45 – JVM 在创建 2031 个线程后死掉
  • 64-bit Ubuntu Linux, Java 1.7.0_45 – JVM 在创建 31893 个线程后死掉
  • 64-bit Windows 7, Java 1.7.0_45 – 因为这个 OS 使用了一个不同的线程模型, 在这个平台上似乎没有抛出该错误. 在线程达到 250,000 后, 进程仍然存活, 尽管 swap 区已经使用了 10GB, 同时应用面临非常严重的性能问题.

所以, 在引入一个小测试时前, 确保你知道你的电脑的限制, 来发现什么时候 java.lang.OutOfMemoryError: Unable to create new native thread 会被触发.

5.4 解决方案

有时候, 你可以通过增加 OS 层面的限制来绕过这个 Unable to create new native thread 问题. 例如, 如果你限制了 JVM 在 user space 可以生成的max user processes, 那么你应该检查并尝试增大这个限制:

[root@dev ~]# ulimit -a
core file size          (blocks, -c) 0
--- cut for brevity ---
max user processes              (-u) 1800
SHELL

通常情况下,因为本机达到线程的限制而抛出 OutOfMemoryError 错误提示可能表明有编程错误. 当你的应用生成了上千个线程, 很有可能有些地方出了大问题 – 没有太多的应用程序可以从如此大量的线程中获益(线程过多, 过犹不及)。

解决这个问题的一个办法是做线程快照 (thread dump) 来理解这个场景. 你可能会花费好几天做这个事情. 这时候, 联系我就是最好的方式(@ ̄ー ̄@).

相关文章
|
4月前
|
存储 缓存 Java
【高薪程序员必看】万字长文拆解Java并发编程!(5):深入理解JMM:Java内存模型的三大特性与volatile底层原理
JMM,Java Memory Model,Java内存模型,定义了主内存,工作内存,确保Java在不同平台上的正确运行主内存Main Memory:所有线程共享的内存区域,所有的变量都存储在主存中工作内存Working Memory:每个线程拥有自己的工作内存,用于保存变量的副本.线程执行过程中先将主内存中的变量读到工作内存中,对变量进行操作之后再将变量写入主内存,jvm概念说明主内存所有线程共享的内存区域,存储原始变量(堆内存中的对象实例和静态变量)工作内存。
141 0
|
2月前
|
安全 C语言 C++
比较C++的内存分配与管理方式new/delete与C语言中的malloc/realloc/calloc/free。
在实用性方面,C++的内存管理方式提供了面向对象的特性,它是处理构造和析构、需要类型安全和异常处理的首选方案。而C语言的内存管理函数适用于简单的内存分配,例如分配原始内存块或复杂性较低的数据结构,没有构造和析构的要求。当从C迁移到C++,或在C++中使用C代码时,了解两种内存管理方式的差异非常重要。
122 26
|
3月前
|
Java 物联网 数据处理
Java Solon v3.2.0 史上最强性能优化版本发布 并发能力提升 700% 内存占用节省 50%
Java Solon v3.2.0 是一款性能卓越的后端开发框架,新版本并发性能提升700%,内存占用节省50%。本文将从核心特性(如事件驱动模型与内存优化)、技术方案示例(Web应用搭建与数据库集成)到实际应用案例(电商平台与物联网平台)全面解析其优势与使用方法。通过简单代码示例和真实场景展示,帮助开发者快速掌握并应用于项目中,大幅提升系统性能与资源利用率。
104 6
Java Solon v3.2.0 史上最强性能优化版本发布 并发能力提升 700% 内存占用节省 50%
|
3月前
|
消息中间件 缓存 固态存储
说一说 Java 中的内存映射(mmap)
我是小假 期待与你的下一次相遇 ~
137 1
说一说 Java 中的内存映射(mmap)
|
3月前
|
缓存 监控 Cloud Native
Java Solon v3.2.0 高并发与低内存实战指南之解决方案优化
本文深入解析了Java Solon v3.2.0框架的实战应用,聚焦高并发与低内存消耗场景。通过响应式编程、云原生支持、内存优化等特性,结合API网关、数据库操作及分布式缓存实例,展示其在秒杀系统中的性能优势。文章还提供了Docker部署、监控方案及实际效果数据,助力开发者构建高效稳定的应用系统。代码示例详尽,适合希望提升系统性能的Java开发者参考。
148 4
Java Solon v3.2.0 高并发与低内存实战指南之解决方案优化
|
2月前
|
SQL 缓存 安全
深度理解 Java 内存模型:从并发基石到实践应用
本文深入解析 Java 内存模型(JMM),涵盖其在并发编程中的核心作用与实践应用。内容包括 JMM 解决的可见性、原子性和有序性问题,线程与内存的交互机制,volatile、synchronized 和 happens-before 等关键机制的使用,以及在单例模式、线程通信等场景中的实战案例。同时,还介绍了常见并发 Bug 的排查与解决方案,帮助开发者写出高效、线程安全的 Java 程序。
137 0
|
2月前
|
存储 Java
Java对象的内存布局
在HotSpot虚拟机中,Java对象的内存布局分为三部分:对象头(Header)、实例数据(Instance Data)和对齐填充(Padding)。对象头包含Mark Word、Class对象指针及数组长度;实例数据存储对象的实际字段内容;对齐填充用于确保对象大小为8字节的整数倍。
|
3月前
|
存储 Java
说一说 JAVA 内存模型与线程
我是小假 期待与你的下一次相遇 ~
|
3月前
|
存储 监控 Java
Java内存管理集合框架篇最佳实践技巧
本文深入探讨Java 17+时代集合框架的内存管理最佳实践,涵盖不可变集合、Stream API结合、并行处理等现代特性。通过实战案例展示大数据集优化效果,如分批处理与内存映射文件的应用。同时介绍VisualVM、jcmd等内存分析工具的使用方法,总结六大集合内存优化原则,助你打造高性能Java应用。附代码资源链接供参考。
108 3

热门文章

最新文章