Linux -bash: fork: retry: 资源暂时不可用

释放双眼,带上耳机,听听看~!

错误日志如下:

[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

在使用普通用户查看

1651668048090.png

接下来修改系统最大进程数

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.

给TA买糖
共{{data.count}}人
人已赞赏
报错锦集

Windows Server 2016离线安装.NET Framework 3.5

2022-4-25 14:27:55

报错锦集

群晖Transmission 做种时提示红种Unable to save resume file: Too many open files

2022-5-6 11:09:21

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索