“-bash: fork: 没法分配内存”,发现连了好多终端,而后断开了一个终端,而后这边终端能够敲命令了shell
[root@172.16.31.105 /home/www/test]# free -m
total used free shared buffers cached
Mem: 15979 8025 7954 0 218 1109
-/+ buffers/cache: 6697 9282
Swap: 0 0 0vim
卧槽,还有那么多内存。。。很无语,而后又开始敲命令,结果又报刚才那个问题“-bash: fork: 没法分配内存”,另一个终端链接也出问题了bash
[root@172.16.31.102 ~]# ssh 172.16.31.105
shell request failed on channel 0 服务器
网上说老版本系统的内核pid参数比较小(默认设置的是32768),验证了一下,而后我又断开一个终端,这边ps了一下ssh
[root@172.16.31.105 ~]# ps
PID TTY TIME CMD
32775 pts/1 00:00:00 bash
32765 pts/1 00:00:00 ps ide
很明显ps的pid号明显接近于内核默认pid了,当即修改内核pid,并让其生效命令以下:post
echo "kernel.pid_max=64000" >>/etc/sysctl.conf大数据
sysctl -p 队列
生效后,终端马上就能够直连这台机器了。进程
再次验证
找了另一台机器,先多连几个终端,以后将内核pid改小最好近似于当前pid最大值,改完生效后立刻问题就出来了 报 “-bash: fork: 没法分配内存” 接着内核参数
注意:有的机器pid用的比较严重,敲好屡次命令都会报“-bash: fork: 没法分配内存” 所以只能重启服务器,运气好的话多敲几回命令就能够看到。
(二)
还有种状况是系统当前的的进程数 太多太多,报-bash: fork: 没法分配内存
后来发现是由于非root用户打开的进程数太多 解决方法
普通用户的nproc必须配置这个文件才能生效
vi /etc/security/limits.d/90-nproc.conf
vim /etc/security/limits.conf
添加:
* soft nproc 32000
* hard nproc 32000
有关limits.conf参数的注释
- core - 限制核心文件大小(KB)
- data - 最大数据大小(KB)
- fsize - maximum filesize(KB)
- memlock - 最大锁定内存地址空间(KB)
- nofile - 最多打开的文件
- rss - max resident set size(KB)
- stack - 最大堆栈大小(KB)
- cpu - 最大CPU时间(MIN)
- nproc - 最大进程数
- as - 地址空间限制(KB)
- maxlogins - 此用户的最大登陆号
- maxsyslogins - 系统上登陆的最大数量
- priority - 运行用户进程的优先级
- locks - 用户能够容纳的文件锁的最大数量
- sigpending - 待处理信号的最大数量
- msgqueue - POSIX消息队列使用的最大内存(字节)
- nice - 最大优先级容许提升到值:[-20,19]
- rtprio - 最大实时优先级
注:可能致使这种错误的有不少不少,后面若有发现继续更新