微信号:programmer_club

介绍:程序员第一自媒体,与你探讨码农人生路上遇到的各类泛技术话题,定期为你推荐码农人生思考、感悟以及启迪!

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

2018-02-28 22:00 程序员之家

话说

最近有个程序猿很忧桑

....... 



因为弄错了一行代码

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

删没了

没了

...





好吧..

事情是这样的....


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


我在服务器维护的时候不小心执行了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,好不容易做完了,系统问我要保存么?我毅然决然选择了“否”!


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

公众号内回复“1”带你进粉丝群

 
程序员之家 更多文章 公有云四大阵营背后:半壁江山之外的厂商过得咋样 《绝地求生》平底锅挡子弹bug,源于程序员的一个错误 帮程序员减压放松的 10 个良心网站 2017 年,谷歌开源了这些超酷炫的项目 程序员如何独当一面
猜您喜欢 Android你可能要用到的自定义View分享 娱乐圈是一个圈,而互联网是一个网(深度好文) 章亦春(agentzh)谈ngx_lua之来龙去脉 青云的云计算和人工智能生意经 防火防盗防BUG | 有云存储团队公布Ceph中最严重数据不一致BUG!(附修复方案)