首页 > 代码库 > Linux shell 的一个fork炸弹
Linux shell 的一个fork炸弹
.(){ .|.& };. 或者 :(){ :|:& };:
这13个字符由Jaromil ,在 2002 年设计了最为精简的一个 fork炸弹的实现。
.() 说明下面要定义一个函数,函数名为小数点,没有可选参数;
{ 表示函数体的开始;
.|.& 表示函数体真正要做的事情,首先它递归使用本函数,然后李永贵管道调用一个新进程(它要做的事情也是递归调用本函数),并将其放到后台执行。
} 表示函数体的结束;
; 并不会执行什么操作,在命令行中用来分隔两个命令用。从总体来看,它表明这段程序包含两个部分,首先定义了一个函数,然后调用这个函数;
. 表示调用本函数。
这个递归函数能够调用自身,不断地生成新的进程,最终造成拒绝服务攻击,函数调用该前的&将子进程放入后台。这段危险的代码会分支出大量的进程,因而被称为Fork炸弹。
可以通过修改配置文件/etc/security/limits.conf来限制可生成的最大的进程数来避开这枚炸弹。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。