专栏名称: 程序员大咖
为程序员提供最优质的博文、最精彩的讨论、最实用的开发资源;提供最新最全的编程学习资料:PHP、Objective-C、Java、Swift、C/C++函数库、.NET Framework类库、J2SE API等等。并不定期奉送各种福利。
目录
相关文章推荐
OSC开源社区  ·  微软Visual ... ·  5 天前  
OSC开源社区  ·  MySQL亿级数据平滑迁移实战 ·  5 天前  
程序猿  ·  真cv工程师 ·  6 天前  
码农翻身  ·  形势很严重,劝全体码农们做好准备吧! ·  5 天前  
51好读  ›  专栏  ›  程序员大咖

有个程序猿很忧桑:一个命令rm -rf/ ,他把整个公司删没了...

程序员大咖  · 公众号  · 程序员  · 2017-02-10 20:34

正文

来自:英国那些事儿(ID:hereinuk) 和 cnBeta

链接:http://www.cnbeta.com/articles/492731.htm

http://www.independent.co.uk/life-style/gadgets-and-tech/news/man-accidentally-deletes-his-entire-company-with-one-line-of-bad-code-a6984256.html


话说

最近有个程序猿很忧桑

....... 



因为弄错了一行代码

这哥们不小心把他整个公司

删没了

没了

...










好吧..

事情是这样的....


最近有个哥们在个技术论坛上求助...  


我在服务器维护的时候不小心执行了rm -rf 命令...... 现在整台服务器被我删光了肿么办???? 


好吧.. 现在先来介绍一下


rm 是 linux系统下删除文件的命令....   -r 代表删除这个下面的一切,一切的一切那种的一切。  f 表示不需要用户确认,直接执行.....

好吧...通常这个命令都是指定文件夹用的...  比如  

rm -rf  /home/test/   就是删除/home/test/这个文件夹下面的所有东西..... 


但是如果后面的文件夹路径没有加对.........

rm -rf /  在服务器上也就意味着....



哥们当然不会笨到直接去执行这个.... 

他表示,他当时正在运行一个BASH脚本...  但是脚本里似乎有一个问题,导致执行这个删除命令的时候,删除指定文件夹的那个参数没有顺利的传递过去.....  


直观点解释一下?  


让我来给大家举个例子:

我叫小明去让电脑删除一个东西.. 我就是那个程序员,小明就是那个脚本....


我本来想给小明的指令是  

“让电脑把test文件夹下的东西全删了.... ”


但是似乎我跟小明在沟通上出现了问题.... 不知道是他听漏了还是我说错了,总之最后小明跑去执行的指令是   

“让电脑把东西全删了”


电脑: 好的明白~~~


于是... 




公司这台服务器上所有的用户数据... 就在这么一条命令之后强撸灰飞烟灭了...... 


好吧... 那备份的数据呢?


这哥们表示....  当时为了执行维护,他把远程的备份的驱动器也挂在了这个服务器上.....  

于是也这么一起删掉了........ 


后来下面的网友纷纷给这哥们点起了蜡烛....


“哥们我很抱歉的哥你说......  实际上你的公司已经彻底的报销了...."   


 "我觉得你现在就别纠结这些技术细节了..... 找个律师比较有用...."


“如果你现在马上把你这服务器拿去数据恢复公司.. 也许还有一点救.. 不过鉴于你的数据量,修复起来绝对是天文数字”


好吧.....

现在这哥们已经哭不出来了...... 


进一步报道

Marco Marsala 是一家小型主机托管公司的老板,但是他最近遇到了一个天大的麻烦——由于脚本错误,他不慎删光了所有客户的数据。更糟糕的是,由于 Bash 脚本代码中包含了一行变量未定义的“rm -rf {foo}/{bar}”,连备份也连带着被干掉了——而在通常情况下,备份网络理应和正常的生产力基础设施隔离开的。



这一错误源自 Ansible 上糟糕的代码设计,这款 Linux 实用工具被用于在多台不同服务器上自动执行脚本。


开发者解释到,实际参数应该是“rm -rf {foo}/{bar}”,foo 和 bar 是脚本中动态传递的两个变量。

然而由于变量处理出错,通用语法未能成功在 bash 命令中插值,所以最终指令就变成了可怕的“rm -rf /”。

“rm -rf/”意味着擦除根路径“/”下挂载的所有内容而无需询问。


鉴于 Marsala 运行着 1535 个集群,其本来是能够在数小时(至数日)内恢复的。但由于未能妥善实现生产环境和备份环境的隔离,备份档也全没了。


不得已之下,他只能上网发帖求救,然而没人能救得了他了。当然,也许最好的建议是给律师打个电话,那样或许还不至于赔得太惨。




网友评论


提莫采摘蘑菇第一小分队:不太懂 但是我刚刚码完论文然后没保存。


V-Lancelot:我来举一个形象一点的例子,假如你是个网红,你有几千万粉丝,然后有个程序员把数据库删没了,一觉醒来你发现你的几千万粉丝都没了,你会是什么感觉


红红火火嚯嚯呵呵:前些日子,我们公司一个程序员离职,把项目交接好就走了,新来的一个程序员第一天逮到电脑就重装了系统。。项目代码都没了,老板气的键盘砸烂了两个专门拿着硬盘去恢复也失败了,。。。。还好离职的程序员家里还有一份,虽然不是最新的不过也是万幸。神奇的是新来的程序员第二天还来了。


小明说他是故事里的路人甲:同病相怜撒 我刚刚弄错了一个数据 现在可能要赔四千多……


纪冬夏:手下一行码,余生两行泪


lee贝勒:变量{foo}/{bar}前为何不加上$符号,这可是shell变量的引用格式啊


阿涵感觉自己萌萌哒:还记得之前某次大型全球金融危机就是 某个银行职员写错了一个数


好好学习假不假__不假:不懂的各位,就当作新浪的数据都被删除了,微博以后都不存在了就行


钡盐不溶--explode:可以在知乎回答[亲手把一家公司弄垮是怎样的体验]


白玉糖包子:我懂我懂,我花了一晚做的PPT,好不容易做完了,系统问我要保存么?我毅然决然选择了“否”!


农村古天乐:老总:感谢你小伙子,我们不用偿还那些债务了,来,咱商量一下怎么弄个新公司