您好,登錄后才能下訂單哦!
大家好我是歷史,身為liunx系統管理員,rm命令是不是經常在用呢?有沒有做過rm命令以后,瞬間感覺無語的時候!
讓大家看看我的血的教訓!
果真感覺蛋疼了,欲哭無淚啊!寫了一天的成果,想著把之前備份的文件刪除呢,結果把剛寫完的刪了。
國外著名linx管理員守則中有這么一條:“慎用rm -rf命令,除非你知道此命令將帶來什么后果。” 可見這個命令的重要性啊,書中看到的這句話,確實很對。
說了這么多,教教大家執行了rm命令后 該這么辦吧,是有辦法回復的,我剛經過試驗證實了,google有一個開源的包 叫ext3grep工具他可以回復刪除的文件,甚至是drop database xcy; 對,就是誤刪除的數據庫都可以回復。
先說一下他的工作原理吧,然后我在把試驗分享給大家, 工作原理其實也不難,這個工具需要在ext3或者ext4 的文件系統上才可以實現,因為ext3文件系統是日志型文件系統,ext3文件系統儲存信息的時候是由inode號和block塊存儲的。
神馬? 不知道什么是inode號?和block塊? 好吧,在說明白點,比如:一個分區比如一本書,那么block塊就是書每頁的內容,而inode號 就是書的目錄,系統找文件的時候先找inode號 然后根據inode號去找硬盤上的block快信息,明白了吧!
在說一下刪除的原理吧。 當硬盤上的一個文件刪除,其實沒有真正想象中的那樣在硬盤上清除掉的,他是把inode號和block塊的那個鏈子 斷開,但是真正的數據還是在硬盤上的,有沒有感覺在windos上刪除是那么快,沒考慮到這吧,當你在刪除文件的地方重新復制了新文件,那時候才會把之前的文件覆蓋掉,也就是說刪除了沒有關系,千萬不要往那個位置放文件了。
源碼包下載位置:http://down.51cto.com/data/709491
原理說完了,開始實戰。
環境介紹: 系統版本:CentOS release 5.4 (Final)
1 安裝之前先檢查有沒有這個包: rpm -qa | grep e2fsprogs
2 ext4grep 是個源碼包,需要編譯安裝
檢查一下e2fsprogs包是否完整,我的卻一個-devel的包,所以要先yum install e2fsprogs* 我偷懶了嘿嘿
解壓ext3源碼包
進入源碼包,然后開始檢查包的完整性 執行: ./configure 如果在這個過程中到最后有error那么先檢查你的是不是少 e2fsprogs-devel
在進行 make && make install (編譯 編譯安裝) 一般這里不會有問題如果這里報錯了 檢查你系統是不是缺少 gcc gcc-c++ 這倆包 你可以 yum install gcc* 全部安裝 有好處沒有壞處哈哈哈
等待完整完,,好了安裝完以后。可以先查看一個是否完成成功了,用: ext3grep -v 命令查看ext3的版本信息如下如:
當然如果不知道命令怎么用可以輸入:ext3grep --help 查看
然后我需要手動創建一個分區, 創建命令: fdisk /dev/sda 這個因為沒有辦法保存圖像所有我直接顯示的創建完成以后的。如果大家不知道怎么創建 可以查看我的 linx基本命令(文件系統章節)。
然后 把這個分區y用ext3分區格式格式化 并且掛載到mnt目錄下。
然后 我進入了掛載的目錄里, 創建了xcy目錄, 把/etc/passwrd 和 /etc/my.cnf 倆個文件復制到了/mnt/xcy目錄中,并且 把倆個文件改了下名字 為了我的辨認。 最后我執行了 rm -rf /xcy/* 把xcy文件中的文件都刪除了。
咳咳,然后我首先做的是卸載下來 把掛載的分區,因為 怕別人動了我的文件夾 在里面復制了東西我就沒有辦法恢復了,在下面我執行:ext3grep /dev/sda5 --ls --inode 2 給你們解釋一下
ext3grep 刪除文件的分區 --ls --innode inode號
為什么最后我們要寫2 因為我不知道我的刪除的文件的inode號多少, 所有我寫的是最大的inode / 的inode號 可以用: ls -id / 查看
執行下去以后就會看到 他在刷幫你找刪除的文件們。。
然后我們執行 ext3grep /dev/sda5 --restore-inode 2011 (恢復my.cnf.xcy文件)
我們在執行 ext3grep /dev/sda5 --restore-inode 2010 (恢復passwrd.xcy文件)
然后我們將卸載的文件系統重現掛載上去。
恢復了,文件不會在原來的位置,他會自動在/ 下創建一個叫RESTORED_FILES 目錄 你以后所有恢復的文件都會在這里保存著,還有文件的名字是以inode號命名的 你需要手動修改回來原名字,不要怕不知道那個文件是那個,還記得我們 --ls 掃描的時候他都有對應的文件和inode號
文件恢復了,哈哈 是不是很激動啊,解決了liunx 下不能恢復的問題,這樣就可以大大節約成本 不用找硬盤恢復工具 不用花錢了, 對了還有呢, 這個同樣可以恢復 mysql 數據庫 誤操作刪除了庫或者表 都可以恢復 原理嘛 其實就是恢復相對應的mysql數據庫中的文件了,自己嘗試一下吧,
對了在說一下,我截圖中 圈起來了是正確的命令,別的很多有操作錯誤的,因為畢竟第一次試驗嗎。。成功了很高興,,希望能幫到和我同樣遭遇的朋友們。
最后來個總結缺點: 我試驗發現這個功能有些缺點:
1 條件必須是ext3 ext4 日志文件系統才可以做到,別的我就不清楚了。
2 我這個是自己創建的分區/dev/sda5 也就是說我知道刪除的文件在那個分區上,假如你刪除了文件知道在哪里分區中 那么你就需要從sda1 ....sdaN 都試一遍吧,,,,。
有什么問題可以留言 聯系我 我看到了可以幫大家解決。。。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。