“BASH: FORK: RESOURCE TEMPORARILY UNAVAILABLE”的解决方案
这两天,我登陆到一台服务器上,偶尔就出现"bash: fork: Resource temporarily unavailable"的提示,这是什么命令都不能用,但偶尔过一会就好了。前两天也没太在意,今天再次遇到,然后找到了根本原因。
当出现"bash: fork: Resource temporarily unavailable"时,一般来说是系统上的进程数量太多了,达到了命令"ulimit -u"的限制。(当系统进程达到限制后,kernel会自动kill掉一些进程,这就是好我过一会又能操作的原因了。)这种情况产生的原因,一是某个程序有bug,不断地fork新的进程消耗系统资源,二是可能中了病毒(恶意程序),比如所谓的fork炸弹。
我进行了如下操作:
1
2
3
4
5
6
|
[repo@vt-sync jay]$ ulimit -u
1024
[repo@vt-sync jay]$ ps -ef | wc -l
1221
[repo@vt-sync jay]$ ps ux | wc -l
1020
|
发现当前用户下面居然有1020个进程,我仔细一看,很多的"vgt-sync.sh"之类的进程,这个shell脚本是我自己以前写的啊,里面有一个while的死循环,本来单独运行这个脚本是正确的,没有任何问题,但是我却把它配置到crontab任务中每小时都去运行,这样就会每小时都会新增一个vgt-sync.sh进程,随着时间的推移,本机上的进程就越来越多了,从而导致了上面的问题。
所以,我的找到原因,解决方法就简单了,显示kill掉这些进程,然后修改我的脚本,既然用了crontab就别写死循环了。
1
2
3
4
5
6
|
[repo@vt-sync jay]$ ps ux | wc -l
1020
[repo@vt-sync jay]$ killall vgt-sync.sh
#(wait for several seconds.)
[repo@vt-sync jay]$ ps ux | wc -l
12
|
再来看看我的那个非常简单脚本吧,刚好和crontab结合起来使用就有了bug了。
1
2
3
4
5
6
7
8
9
10
11
12
|
#! /bin/bash
set -x
linux_dir="/home/repo/pub/linux-vgt.git/"
xen_dir="/home/repo/pub/xen-vgt.git/"
while [ 1 ]
do
cd $linux_dir
git pull
cd $xen_dir
git pull
sleep 30
done
|
我遇到的情况是自己的程序bug,下面简单说一下fork炸弹吧。
所谓fork炸弹是一种恶意程序,它的内部是一个不断在fork进程的无限循环,fork炸弹并不需要有特别的权限即可对系统造成破坏。现在来看一个最简单的fork炸弹:
1
|
:() { :|:& };:
|
一行看似无法理解的只有13个字符的命令,即可占用掉所有系统的资源。其实,这行命令如果这样写成bash script就不难理解了:
1
2
3
4
5
6
|
:()
{
:|: &
}
;
:
|
冒号":"其实是函数名,这个bash脚本就是在不断的执行该函数,然后不断fork出新的进程。那么,有没有办法扼制这种情况的发生呢?答案是肯定的,只需设置进程的limit数即可,就算fork炸弹运行也没关系,如果我的limit限制很小的话,几百个简单进程也不消耗完系统的所有资源:
ulimit -u 200 #设置当前用户最多的进程数量限制为200
使用工具ulimit即可设置各种限制数,具体的请参考该工具的manual page(man bash)。在这里笔者限制了max user processes数为200,所以,可以安全地执行这个fork炸弹了:
1
2
3
4
5
6
|
[repo@vt-sync jay]$ :() { :|:& };:
[1] 9593
[repo@vt-sync jay]$ bash: fork: Resource temporarily unavailable
bash: fork: Resource temporarily unavailable
bash: fork: Resource temporarily unavailable
bash: fork: Resource temporarily unavailable
|
“BASH: FORK: RESOURCE TEMPORARILY UNAVAILABLE”的解决方案相关推荐
- -bash:fork:Resource temporarily unavailable
Java代码 出现这个问题的原因是linux用户的连接数设置的太小,只要修改max user processes就可以 www.2cto.com 设置各linux 用户的最大进程数, ...
- .git/hooks/commit-msg: fork: Resource temporarily unavailable error: bogus commit object 00000000000
git提交代码的时候遇到了这个问题 .git/hooks/commit-msg: fork: Resource temporarily unavailable error: bogus commit ...
- Linux报Resource temporarily unavailable问题解决方案
当应用程序占满进程数后,则会报错如下 Resource temporarily unavailable 新用户的进程数限制一般都是在2048或者4096. 解决方案 使用root用户登陆,进入到/et ...
- 故障:fork failed:Resource Temporarily Unavailable解决方案
故障:fork failed:Resource Temporarily Unavailable解决方案 在一次crontab bkapp.txt导入N多定时任务时候,该用户无法执行任何命令,再ssh连 ...
- psql: could not fork new process for connection: Resource temporarily unavailable
业务无法和数据库建立连接,上去查看,切换用户就报错 su - postgres su: cannot set user id: Resource temporarily unavailable 看资源 ...
- 关于Ubuntu中 E: Could not get lock /var/lib/dpkg/lock - open (11: Resource temporarily unavailable)解决方案
在Ubuntu中,有时候运用sudo apt-get install 安装软件时,会出现一下的情况 E: Could not get lock /var/lib/dpkg/lock - open ( ...
- Resource temporarily unavailable解决办法
最近在使用虚拟机环境做测试时,常常遇到-bash: fork: retry: Resource temporarily unavailable. 字面意思是资源限制,进程数开的不够大,直接ulimit ...
- Resource temporarily unavailable 错误
2019独角兽企业重金招聘Python工程师标准>>> [root@namenode01 backup]# su - app Last login: Tue Apr 26 09:48 ...
- OpenWrt——Could not lock /var/lock/opkg.lock: Resource temporarily unavailable.
问题描述 root@OpenWrt:~# opkg update Collected errors:* opkg_conf_load: Could not lock /var/lock/opkg.lo ...
最新文章
- php课设报告致谢_PHP学生管理系统毕业论文设计.doc
- [导入]使用SqlCommand对象执行存储过程
- vscode python print 输出窗口中文乱码
- Flask Bind-DLZ + Mysql DNS管理平台
- sql视图查询对象无效_SQL数据分析 - 4 复杂查询
- MS SQL 语句中的字符串连接
- antd option宽度自适应_前端基础:自适应布局之rem布局基础
- ug区域轮廓铣没有重叠距离_UG加工基本操作
- SpringBoot日常游玩---当你需要在一个静态方法中使用一个带有其他@Autowried的实现类的时候怎么办
- gx works2 存储器空间或桌面堆栈不足_2020淮北Gx螺旋输送机价格厂家出售
- 系统集成项目管理工程师14真题解析
- 简单用电脑摄像头实现人脸识别
- nagios 飞信通知
- c4d-学习笔记-4-建模
- php文字转拼音API接口下载,微擎API 开发之汉字转拼音助手
- 解决Docker下载镜像速度太慢
- 解答诸葛亮反思的七条内容
- 喹啉羧酸类 DHODH 抑制剂用于治疗急性髓系白血病
- 【前端小实战】百度新闻雪碧图及动画(CSS sprites)
- HDOJ 1814 Peaceful Commission