不小心執(zhí)行了rm?
不小心執(zhí)行 rm -f,不要急著跑路!!
每當(dāng)我們在生產(chǎn)環(huán)境服務(wù)器上執(zhí)行rm命令時,總是提心吊膽的,因?yàn)橐徊恍⌒膱?zhí)行了誤刪,然后就要準(zhǔn)備跑路了,畢竟人不是機(jī)器,更何況機(jī)器也有bug,呵呵。
那么如果真的刪除了不該刪除的文件,比如數(shù)據(jù)庫、日志或執(zhí)行文件,咋辦呢?不要急著跑路了,這樣做還可以恢復(fù)!
模擬場景
1、刪除
誤刪除服務(wù)器目錄/root/selenium/Spider下的MySql.Data.dll文件:
> rm -f /root/selenium/Spider/MySql.Data.dll
> ll /root/selenium/Spider/MySql.Data.dll
ls: cannot access /root/selenium/Spider/MySql.Data.dll: No such file or directory
2、恢復(fù)
(1)、使用lsof命令查看當(dāng)前是否有進(jìn)程打開/root/selenium/Spider/MySql.Data.dll文件:
> lsof | grep /root/selenium/Spider/MySql.Data.dll
從上面可以看出,當(dāng)前文件狀態(tài)為已刪除(deleted)。
(2)、查看是否存在恢復(fù)數(shù)據(jù):
> cat /proc/13067/fd/86
(3)、使用I/O重定向恢復(fù)文件
> cat /proc/23778/fd/86 > /root/selenium/Spider/MySql.Data.dll
> ls -l /root/selenium/Spider/MySql.Data.dll
-rw-r--r-- 1 root root 702464 Feb 10 12:03 /root/selenium/Spider/MySql.Data.dll
重新運(yùn)行程序:
說明恢復(fù)的文件沒有問題。
刨根問底
通過前面的模擬場景演示了恢復(fù)文件的整個過程,那么原理是什么,在什么情況下,文件才是可恢復(fù)的。
在Linux系統(tǒng)中,每個運(yùn)行中的程序都有一個宿主進(jìn)程彼此隔離,以/proc/進(jìn)程號來體現(xiàn)(Linux本質(zhì)上就是一個文件系統(tǒng)),比如:ls -l /proc/13067 查看進(jìn)程PID為13067的進(jìn)程信息;當(dāng)程序運(yùn)行時,操作系統(tǒng)會專門開辟一塊內(nèi)存區(qū)域,提供給當(dāng)前進(jìn)程使用,對于依賴的文件,操作系統(tǒng)會發(fā)放一個文件描述符,以便讀寫文件,當(dāng)我們執(zhí)行 rm -f 刪除文件時,其實(shí)只是刪除了文件的目錄索引節(jié)點(diǎn),對于文件系統(tǒng)不可見,但是對于打開它的進(jìn)程依然可見,即仍然可以使用先前發(fā)放的文件描述符讀寫文件,正是利用這樣的原理,所以我們可以使用I/O重定向的方式來恢復(fù)文件。
總結(jié)
如果不小心誤刪了文件,不要著急,首先使用 lsof 查看打開該文件的進(jìn)程,然后再使用 cat /proc/進(jìn)程號/fd/文件描述符 查看恢復(fù)數(shù)據(jù),最后使用I/O重定向的方式來恢復(fù)文件。