(转载)Linux下修改ulimit设置的最大进程数

(转载)Linux下修改ulimit设置的最大进程数,第1张

Linux下修改ulimit设置的最大进程

最近在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

以下是说明:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/7789789.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-09
下一篇 2023-04-09

发表评论

登录后才能评论

评论列表(0条)

保存