OutOfMemoryError: unable to create new native thread.

蔚落 2024-03-17 16:11 159阅读 0赞

在java应用中,有时候会出现这样的错误:OutOfMemoryError: unable to create new native thread.

根据公式
(MaxProcessMemory - JVMMemory - ReservedOsMemory) / (ThreadStackSize) = Number of threads
参考: (java进程里如何估算jvm最大线程数)

每一个32位的进程最多可以使用2G的可用内存,因为另外2G被操作系统保留。这里假设1.5G给JVM,操作系统保留120M内存:

对于jdk1.5而言,栈大小为 1M
1.5GB allocated to JVM: (2GB-1.5Gb-120MB)/(1MB) = ~380 threads
1.0GB allocated to JVM: (2GB-1.0Gb-120MB)/(1MB) = ~880 threads

对于jdk1.4而言,栈大小为 256KB
1.5GB allocated to JVM: ~1520 threads
1.0GB allocated to JVM: ~3520 threads

分析
要么JVMMemory分配过大,要么ThreadStackSize分配过大

方案:
1、减少分配给JVM的最大内存
2、通过-Xss / -XX:ThreadStackSize减少线程最大栈空间大小
3、还有一种做法是让JVM宿主在你的JNI代码里边

发表评论

表情:
评论列表 (有 0 条评论,159人围观)

还没有评论,来说两句吧...

相关阅读