背景
前段时间,经公司护网行动安全要求,需要对部署在 tomcat 等服务器上的程序进行安全漏洞扫描,楼主在没任何工作交接的情况下,只能自己动手把 war 从 tomcat 所在服务器下载下来。可是楼主在备份 war 包的过程中,用rm -rf
命令误删除了某个文件上传共享目录(war 包中有些文件太大,下载不了,所以要删除。),导致很多新闻展示不了。经过一个通宵达旦的各种前抢修和数据恢复,还是有部分数据丢失。万幸的是这个应用快要下线了,数据少几条没关系,现在回过头来想想,只能阿弥陀佛了。
删除原理分析
当有人告诉我数据不能完全恢复时,我蒙B了五分钟,这种事尽然发生在我身上。。。面壁。。。
原理分析
当硬盘上的一个文件删除,其实没有真正想象中的那样在硬盘上清除掉的,它是把 inode 号和 block 块的链子断开,但是真正的数据还是在硬盘上的,有没有感觉比在 windows上删除快,当你在删除文件的地方重新复制了新文件,那时候才会把之前的文件覆盖掉,也就是说删除了没有关系,千万不要往那个位置放文件了。
也就是说,删除了文件不要紧,但是一定不要在原先的文件地方再次写入新的文件,因为这会触发真正的覆盖原先文件,也就是真正的删除文件,再也恢复不了了。
文件如何恢复
可以用 ext3grep
工具进行文件恢复,前提是要求你的系统是在 ext3 或者 ext4 的文件系统,因为 ext3 文件系统是日志型文件系统,ext3 文件系统储存信息的时候是由 inode 号和 block 块存储的。
ext3grep 教程参考:https://www.cnblogs.com/lazyfang/p/7699994.html
rm 常用参数
常用参数说明
-f, --force 强制删除。忽略不存在的文件,不提示确认-i 在删除前需要确认-r, -R, --recursive 递归删除目录及其内容-v, --verbose 详细显示进行的步骤
询问式删除文件
rm 文件名
删除文件时,系统会先询问是否删除。
例子:
代码语言:javascript复制rm a.log
强制删除目录和文件
代码语言:javascript复制rm -rf 目录名
rm -rf
会强行删除该目录以及所有文件、子目录下的所有文件和目录。
例子:
代码语言:javascript复制rm -rf /data/logs
通配符删除文件
代码语言:javascript复制rm -rf *
通过 * 表示删除当前目录下所有目录和文件。
例子:删除目录下以 log 扩展名结尾的所有日志文件
代码语言:javascript复制rm -f *.log*
经验总结
1、做好源程序和线上 war 包备份
2、慎用 rm 命令,改用 mv 命令
3、做好关键文件和数据备份
4、慎用你的自信心,在不了解系统情况下,尽量不要动手,背锅侠不好当