2020/05/21

如何避免週期性的備份檔案撐爆硬碟?

假設某個程式可排程自動備份Log或資料,但沒有像 SQL Srv 可在管理維護計畫中,刪除檔案存在的時間,若檔案很大且一直產出,日積月累硬碟就會被塞爆了,因此可寫個 bat 批次檔,在伺服器閒置時排程去K掉它。


批次檔內容要如何寫? C:\Users\nico>FORFILES /?
FORFILES [/P pathname] [/M searchmask] [/S] [/C command] [/D [+ | -] {yyyy/MM/dd | dd}]



描述:
    選取一個檔案 (或一組檔案),並在檔案上執行命令。這對批次工作很有幫助。

參數清單:
    /P    pathname      表示要開始搜尋的路徑。預設資料夾是目前的目錄 (.)。

    /M    searchmask    根據 searchmask 搜尋檔案。預設的 searchmask 是 '*'。

    /S                  指示 forfiles 遞迴搜尋子目錄。例如 "DIR /S"。

    /C    command       表示每個檔案要執行的命令。
                                   命令字串應該包含在雙括號之間。

                        預設的命令是 "cmd /c echo @file"。

                        下列變數可以使用於命令字串:

                        @file    - 傳回檔案的名稱。
                        @fname   - 只傳回檔案的名稱,不傳回副檔名。
                        @ext     - 只傳回檔案的副檔名。
                        @path    - 傳回檔案的完整路徑。
                        @relpath - 傳回檔案的相對路徑。
                        @isdir   - 如果檔案類型是目錄的話,傳回 "TRUE",如果是檔案的話,傳回 "FALSE"。
                        @fsize   - 傳回檔案的大小,單位是位元組。
                        @fdate   - 傳回檔案上次修改的日期。
                        @ftime   - 傳回檔案上次修改的時間。

                        要在命令列中包含特殊字元的話,請使用 0xHH 格式的十六進位字元碼 (例如 0x09 代表 tab)。
                        內部的 CMD.exe 命令應該以 "cmd /c" 執行。

    /D    date          選取檔案上次修改的時間大於或等於 (+) 、小於或等於 (-),使用 "yyyy/MM/dd" 格式指定的日期;或選取檔案上次修改的時間大於或等於 (+)
                        目前的日期再加上 "dd" 天、小於或等於 (-) 目前的日期減去 "dd" 天。
                        有效的 "dd" 可以是介於 0 - 32768 之間的數字。
                        如果未指定,"+" 將被視為預設符號。

範例:
    FORFILES /?
    FORFILES
    FORFILES /P C:\WINDOWS /S /M DNS*.*
    FORFILES /S /M *.txt /C "cmd /c type @file | more"
    FORFILES /P C:\ /S /M *.bat
    FORFILES /D -30 /M *.exe /C "cmd /c echo @path 0x09 was changed 30 days ago"
    FORFILES /D 2001/01/01 /C "cmd /c echo @fname is new since Jan 1st 2001"
    FORFILES /D +2020/5/22 /C "cmd /c echo @fname is new today"
    FORFILES /M *.exe /D +1
    FORFILES /S /M *.doc /C "cmd /c echo @fsize"
    FORFILES /M *.txt /C "cmd /c if @isdir==FALSE notepad.exe @file"

列出 D:\capture 底下超過 30 天的 *.jpg 檔案(含子目錄)
FORFILES /P "D:\capture" /M "*.jpg" /S /C "cmd /c echo @path" /D -30

刪除 C:\backup\CardSQL 底下超過 10 天的 *.bak 檔案(不處理子目錄)
FORFILES /P "D:\backup\CardSQL\" /M "*.bak" /C "cmd /c del @path" /D -10

沒有留言: