OutOfMemoryError: unable to create new native thread.
在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代码里边
还没有评论,来说两句吧...