错误日志如下:
[epm24@mcsvpa01 consolidation_linux]$ ps -ef|grep oracle
-bash: fork: retry: 资源暂时不可用
-bash: fork: retry: 资源暂时不可用
-bash: fork: retry: 资源暂时不可用
-bash: fork: retry: 资源暂时不可用
此时无法执行ps -ef过滤命令
解决方法,一般是文件打开数、最大线程数超过了系统默认设置
这时候我们需要先切换到root用户,执行资源清除
[root@mcsvpa01 ~]# ps -ef|grep oracle|awk -F "[ ]+" '{print $2}'|xargs kill -9
在使用普通用户查看
接下来修改系统最大进程数
root 账号下 ulimit -u 出现到 max user processes 的值 默认是 # cat /proc/sys/kernel/threads-max 的值 / 2,即系统线程数的一半
普通账号下 ulimit -u 出现的 max user processes 的值 默认是 /etc/security/limits.d/20-nproc.conf (centos6 是 90-nproc.conf) 文件中的
如何修改这个值
1.在/etc/security/limits.conf
文件里添加如下内容
- soft nproc 65535 #打开进程数
- hard nproc 65535 #打开进程数
操作方法:
echo "* soft nproc 65535" >> /etc/security/limits.conf
echo "* hard nproc 65535" >> /etc/security/limits.conf
注意:修改这里,普通用户 max user processes
值是不生效的,需要修改 /etc/security/limits.d/20-nproc.conf
文件中的值。
如果使用 * 号让全局用户生效是受文件 /etc/security/limits.d/20-nproc.conf
中 nproc 值大小制约的,而如果仅仅是针对某个用户,那么就不受该文件 nproc 值大小的影响。
2.修改 /etc/security/limits.d/20-nproc.conf
20-nproc.conf文件名称不唯一,需要根据实际情况修改编辑
因为普通用户受这个文件里的值影响
修改为:
* soft nproc 65535
3.系统总限制
其实上面的 max user processes 65535 的值也只是表象,普通用户最大进程数无法达到 65535 ,因为用户的 max user processes 的值,最后是受全局的 kernel.pid_max 的值限制的。也就是说 kernel.pid_max=1024,那么你用户的 max user processes 的值是127426,用户能打开的最大进程数还是1024.