服務器每周會產生一次全局備份文件,大小約100G左右,需要定期清理。
工作時間網站訪問大,服務器I/O高的時候刪除大數據會對服務器狀態產生不好的影響。于是想利用計劃任務自動執行。
在我的備份目錄/bakcup下,每次備份文件均以日期形式命名目錄名:
-type d:設置查找類型為目錄
-mtime +28:查找28天前的目錄
查找結束后可用-exec參數連接刪除命令
最后可以把命令放入腳本,設置crontab自動執行。
提醒:
使用命令前,應先在服務器上試用查找部分的命令,如只查找出要清理的目錄,則可以繼續。
不排除某些系統會將./目錄查找出來,一定要看清楚,防止出現意外情況。
另外可將-exec替換為-ok,效果相同,在刪除前提醒用戶確認。
PS:rm命令與rsync命令的效率比較
rm
rm命令大量調用了lstat64和unlink,可以推測刪除每個文件前都從文件系統中做過一次lstat操作。
lstat64的次數低于文件總數,還有另外的原因,之后會在另一篇文章中說明。
getdirentries64這個調用比較關鍵。
過程:正式刪除工作的第一階段,需要通過getdirentries64調用,分批讀取目錄(每次大約為4K),在內存中建立rm的文件列表;第二階段,lstat64確定所有文件的狀態;第三階段,通過unlink執行實際刪除。這三個階段都有比較多的系統調用和文件系統操作。
rsync
rsync所做的系統調用很少。
沒有針對單個文件做lstat和unlink操作。
命令執行前期,rsync開啟了一片共享內存,通過mmap方式加載目錄信息。
只做目錄同步,不需要針對單個文件做unlink。
另外,在其他人的評測里,rm的上下文切換比較多,會造成System CPU占用較多——對于文件系統的操作,簡單增加并發數并不總能提升操作速度。
新聞熱點
疑難解答