首页 > 其他分享 >OOM unable to create new native thread 解决办法

OOM unable to create new native thread 解决办法

时间:2022-10-12 16:34:55浏览次数:80  
标签:java thread OOM 创建 create unable 线程 内存 new

java.lang.OutOfMemoryError共有8种类型,其中java.lang.OutOfMemoryError: unable to create new native thread是很常见的一种,这类错误通常发生在应用试图创建新线程时。

 

可能原因

1. 系统内存耗尽,无法为新线程分配内存
2. 创建线程数超过了操作系统的限制


解决方案

1. 排查应用是否创建了过多的线程

通过jstack确定应用创建了多少线程?超量创建的线程的堆栈信息是怎样的?谁创建了这些线程?一旦明确了这些问题,便很容易解决。



2. 调整操作系统线程数阈值
操作系统会限制进程允许创建的线程数,使用ulimit -u命令查看限制。某些服务器上此阈值设置的过小,比如1024。一旦应用创建超过1024个线程,就会遇到java.lang.OutOfMemoryError: unable to create new native thread问题。如果是这种情况,可以调大操作系统线程数阈值。


3. 增加机器内存
如果上述两项未能排除问题,可能是正常增长的业务确实需要更多内存来创建更多线程。如果是这种情况,增加机器内存。


4. 减小堆内存
一个老司机也经常忽略的非常重要的知识点:线程不在堆内存上创建,线程在堆内存之外的内存上创建。所以如果分配了堆内存之后只剩下很少的可用内存,依然可能遇到java.lang.OutOfMemoryError: unable to create new native thread。考虑如下场景:系统总内存6G,堆内存分配了5G,永久代512M。在这种情况下,JVM占用了5.5G内存,系统进程、其他用户进程和线程将共用剩下的0.5G内存,很有可能没有足够的可用内存创建新的线程。如果是这种情况,考虑减小堆内存。


5. 减少进程数
这和减小堆内存原理相似。考虑如下场景:系统总内存32G,java进程数5个,每个进程的堆内存6G。在这种情况下,java进程总共占用30G内存,仅剩下2G内存用于系统进程、其他用户进程和线程,很有可能没有足够的可用内存创建新的线程。如果是这种情况,考虑减少每台机器上的进程数。


6. 减小线程栈大小

线程会占用内存,如果每个线程都占用更多内存,整体上将消耗更多的内存。每个线程默认占用内存大小取决于JVM实现。可以利用-Xss参数限制线程内存大小,降低总内存消耗。例如,JVM默认每个线程占用1M内存,应用有500个线程,那么将消耗500M内存空间。如果实际上256K内存足够线程正常运行,配置-Xss256k,那么500个线程将只需要消耗125M内存。(注意,如果-Xss设置的过低,将会产生java.lang.StackOverflowError错误)

 

参考

https://blog.fastthread.io/2016/07/06/troubleshoot-outofmemoryerror-unable-to-create-new-native-thread/

   摘自:https://blog.csdn.net/wchgogo/article/details/78185643

标签:java,thread,OOM,创建,create,unable,线程,内存,new
From: https://www.cnblogs.com/jokerWzz/p/16784940.html

相关文章

  • 【高并发】ScheduledThreadPoolExecutor与Timer的区别和简单示例
    JDK1.5开始提供ScheduledThreadPoolExecutor类,ScheduledThreadPoolExecutor类继承ThreadPoolExecutor类重用线程池实现了任务的周期性调度功能。在JDK1.5之前,实现任务的......
  • 【Java】线程Thread类常用方法
    1.Thread类中常用方法Thread类常用方法描述start()启动当前线程,调用当前线程的run()方法。run()通常需要重写该方法,将线程要执行的操作写在此方法中。cu......
  • BAPI_SALESORDER_CREATEFROMDAT2创建销售订单(并修改价格)
    只是做个简单记录,用的时候方便copy修改大致的代码如下:FORMfrm_create_so. DATA:lw_showLIKELINEOFgt_show. FIELD-SYMBOLS......
  • PostgreSQL Create Index Concurrently
    PostgreSQL支持在线创建索引(CREATEINDEXCONCURRENTLY),不堵塞其他会话对被创建索引表的DML(INSERT,UPDATE,DELETE)操作。PostgreSQL提供了一个创建索引的高效特性,即“并发......
  • MongoDB Create 操作笔记
    MongoshellCreate操作官方文档地址:https://www.mongodb.com/docs/manual/reference/insert-methods/中文文档地址:https://mongodb.net.cn/manual/reference/insert-m......
  • ETHREAD APC 《寒江独钓》内核学习笔记(4)
    继续学习windows中和线程有关系的数据结构:ETHREAD、KTHREAD、TEB 1.相关阅读材料《windows内核原理与实现》---潘爱民   2.数据结构分析我们知道,windows内核中......
  • Thread专题(6) - 取消和关闭
    此文被笔者收录在系列文章​​​架构师必备(系列)​​中,java中没有提供任何机制,来安全是强迫线程停止手头的工作,Thread.stop和Thread.suspend方法存在严重的缺陷,不能使用。......
  • Thread专题(13) - java存储模型
    此文被笔者收录在系列文章​​​架构师必备(系列)​​中存储模型java语言规范规定了JVM要维护内部线程类似顺序化语意,只要程序的最终结果等同于它在严格的顺序环境中执行的......
  • Thread专题(14) - 自定义Annocation
    此文被笔者收录在系列文章​​​架构师必备(系列)​​中,这一章的注解是非官方的注解,属于一点扩展知识。自从java有了注解能力后,在有些时候可以考虑用注释来代替文档。@Guard......
  • Thread专题(5) - 任务执行
    此文被笔者收录在系列文章​​​架构师必备(系列)​​中,所谓任务就是抽象、离散的工作单元。把一个应用程序的工作分离到任务中,可以简化程序的管理,这种分离还在不同事务间划......