最近在Linux服务器上发布应用时碰到一个如下的异常:
Caused by: java.lang.OutOfMemoryError: unable to create new native thread
at java.lang.Thread.start0(Native Method)
at java.lang.Thread.start(Thread.java:640)
初看可能会认为是系统的内存不足,如果这样想的话就被这段提示带到沟里面去了。
上面这段错误提示的本质是Linux *** 作系统无法创建更多进程,导致出错。因此要解决这个问题需要修改Linux允许创建更多的进程。
修改Linux最大进程数
我们可以通过ulimit -a来查看当前Linux系统的一些系统参数。
$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 62357
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 65536
pipe size(512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 4096
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
在上面这些参数中,通常我们关注得比较多的是一个进程可打开的最大文件数,即open files。系统允许创建的最大进程数量即是max user processes 这个参数。 我们可以使用 ulimit -u 4096 修改max user processes的值,但是只能在当前终端的这个session里面生效,重新登录后仍然是使用系统默认值。
正确的修改方式是修改/etc/security/limits.d/90-nproc.conf文件中的值。先看一下这个文件包含什么:
$ cat /etc/security/limits.d/90-nproc.conf
我们只要修改上面文件中的4096这个值,即可。
相关阅读:
关于RHEL6中ulimit的nproc限制 http://www.linuxidc.com/Linux/2012-12/76255.htm
Linux/Unix ulimit命令详解 http://www.linuxidc.com/Linux/2012-10/72782.htm
Linux 文件系统限制ulimit用法 http://www.linuxidc.com/Linux/2012-06/63451.htm
Linux认证辅导:Linux ulimit命令 http://www.linuxidc.com/Linux/2011-06/37269.htm
Linux主机通过 ulimit 改善系统性能 http://www.linuxidc.com/Linux/2011-03/33121.htm
通过 ulimit 改善Linux系统性能 http://www.linuxidc.com/Linux/2009-11/23109.htm
在Linux中,可以通过修改ulimit值来修改打开文件数的限制。以下是具体步骤:查看当前的ulimit值
在终端输入以下命令:
plaintext
Copy code
ulimit -n
该命令将输出当前的打开文件数限制。
2. 修改ulimit值
如果需要增加打开文件数的限制,可以使用以下命令:
plaintext
Copy code
ulimit -n <new_value>
其中,<new_value>为新的打开文件数限制值。例如,要将打开文件数限制增加到2048,可以使用以下命令:
plaintext
Copy code
ulimit -n 2048
永久修改ulimit值
如果希望永久修改打开文件数限制,可以在/etc/security/limits.conf文件中添加以下内容:
plaintext
Copy code
* soft nofile <new_value>
* hard nofile <new_value>
其中,<new_value>为新的打开文件数限制值。添加以上内容后,重启计算机即可生效。
需要注意的是,在以上 *** 作中,*表示适用于所有用户,soft表示软限制,hard表示硬限制。软限制表示当前可用的最大值,硬限制表示真正的最大值,只有超级用户可以修改硬限制。因此,建议使用软限制进行修改,以免影响其他用户的使用。
当进程打开的文件数目超过此限制时,该进程就会退出。因此,有时需要修改此限制。linux调优之修改最大连接数(ulimit命令)
如果只是普通用户,只是暂时的修改ulimit -n,可以直接shell命令来修改(ulimit -n 1024000)。
但是这个设置时暂时的保留!当我们退出bash后,该值恢复原值。
如果要永久修改ulimit,需要修改/etc/security/limits.conf。limits.conf配置(ulimit设置永久生效)
vim /etc/security/limits.conf
以下是说明:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)