對於出現/bin/sh: fork: retry: 資源暫時不可用這樣的報錯時,說明Linux的open file最大連接數已滿。
1、通過ulimit -a命令查看可以看到該用戶的max user processes值
-bash-4.1$ 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) 127209
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 65535
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) 1024
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
2、解決的方法如下:
切換至root用戶依次執行
2.1 centos6中修改/etc/security/limits.d/90-nproc.conf文件,centos7中修改/etc/security/limits.d/20-nproc.conf。
將npoc設置最大。修改后,內容如下:
cat /etc/security/limits.d/90-nproc.conf
* soft nproc 65535
root soft nproc unlimited
2.2 修改/etc/security/limits.conf,增加nofile。修改方法如下:
echo "* - nofile 65535" >> /etc/security/limits.conf
echo "* - noproc 65535" >> /etc/security/limits.conf
其中:
-
- 代表針對所有用戶,noproc 是代表最大進程數,nofile 是代表最大文件打開數
-
- 的意思為soft 和hard 全部限制
2.3 /sbin/sysctl -p 使配置生效
-bash-4.1$/sbin/sysctl -p
-bash-4.1$ 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) 127209
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 65535
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) 65535 # Linux的open file最大連接數已經修改
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited