日期:2014-05-16  浏览次数:20738 次

解决Red Hat Linux 6.1上的OOM: unable to create new native thread问题

在缺省配置的Red Hat Linux 6.1上运行一个大型、复杂的Java系统,如果这个Java系统会启动多个Java进程,每个进程又会有很多线程,那在运行的时候很可能会遇到java.lang.OutOfMemoryError: unable to create new native thread

?

遇到这个问题大家一般会想到去调整JVM的内存设置,但实际上这极可能是Linux本身的ulimit设置过小,调整JVM的内存设置根本没用。Linux本身限制了每个用户可以启用的最大进程数(Max User Processes),如果这个值相对程序来说很小,那程序运行的时候就会出现致命的错误

?

ulimit -a命令可以查看当前的ulimit设置。Red Hat Linux 5.x缺省的Max User Processes是16384;而Red Hat Linux?6.1缺省的Max User Processes已经改成了1024,对大型、复杂的Java系统来说,1024确实小了点儿

?

我们可以根据系统的情况设置Max User Processes。如果只是当前用户暂时使用,可以执行命令:

ulimit -u new-max-user-processes-value

?如果要对所有用户生效,用root用户修改/etc/security/limits.d/90-nproc.conf文件的如下内容:

* soft nproc new-max-user-processes-value

?然后重启系统令其生效

?