測試文字功能,小工具,標題

記錄很重要,不然會浪費很多時間在找以前的記憶

一個人的氣度,決定他未來的高度。

2015年3月5日 星期四

Bat 本機備份到異機上 7-zip

 Bat 本機備份到異機上
本機是192.168.1.1 備份到192.168.1.123跟1.100
在從使用中的複製到這邊來,修改過程可能會一些小錯誤,使用前要測試一下



:: 設定 日期 變數 =====================================================================================

for /f "tokens=1,2,3 delims=/ " %%i in ("%date%") do set CUR-DRB=%%i-%%j-%%k

:: 設定 日期 變數 i=y j=m k=d , SQL要用的
for /f "tokens=1,2,3 delims=/ " %%i in ("%date%") do set CUR-DRB-SQL=%%j-%%k-%%i

::工作排程找不到要刪的資料夾, 可能會出現0x2訊息
::設定刪除資料夾日期變數 前7天 6/1會刪掉5/25資料夾
echo wscript.echo dateadd("d",-7,date) >%tmp%\tmp.vbs
for /f "tokens=1 delims=/" %%a in ('cscript /nologo %tmp%\tmp.vbs') do set yyyy=%%a
for /f "tokens=2 delims=/" %%b in ('cscript /nologo %tmp%\tmp.vbs') do set mm=%%b
for /f "tokens=3 delims=/" %%c in ('cscript /nologo %tmp%\tmp.vbs') do set dd=%%c

::補 0 , 要用來刪資料夾的
if %mm% LEQ 9 set mm=0%mm%
if %dd% LEQ 9 set dd=0%dd%
set filename=%yyyy%-%mm%-%dd%

REM 每天備份WEB開始,先寫記錄時間 =====================================================================================

echo 開始 ZIP 時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% > C:\BACKUPBAT\logs\%CUR-DRB%.log

path C:\Program Files\7-Zip

7z a -tzip D:\WEB_BACKUP\%CUR-DRB%\JAVA_%CUR-DRB%.zip D:\JAVA\ >> C:\BACKUPBAT\logs\%CUR-DRB%.log

echo 完成 ZIP 時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

:: 刪資料夾,刪7天前的資料夾
RD /S /Q D:\WEB_BACKUP\%filename%

REM 一二三四五六日,xp是顯示星期,不是週
REM if not "%date:~11,2%" =="週日" goto go_to_exit

REM 每周備份WEB_TO_1_123開始,先寫記錄時間 ===========================================================================

echo WEB_BY_WEEK_TO_1_123 開始備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

::Set 備份到192.168.1.123參數
set SERVER_NAME=192.168.1.123
set SERVER_PATH=backup\192_168_1_1\web
net use "\\%SERVER_NAME%" /user:lsadmin 1gnutat

:: 備份 本機 到 異機
robocopy D:\WEB_BACKUP\%CUR-DRB%\ \\%SERVER_NAME%\%SERVER_PATH%\%CUR-DRB% /mir /COPY:DT /FFT >> C:\BACKUPBAT\logs\%CUR-DRB%.log
if '%errorlevel%' NEQ '1' exit /B

:: 刪遠端的資料夾,刪7天前的資料夾
RD /S /Q \\%SERVER_NAME%\%SERVER_PATH%\%filename%

::斷掉原本連線
net use "\\%SERVER_NAME%" /delete

echo WEB_BY_WEEK_TO_1_123 完成備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

REM 每周備份SQL_TO_1_123開始,先寫記錄時間 ===========================================================================

echo SQL_BY_WEEK_TO_1_123 開始備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

::設定路徑
set SERVER_PATH=BACKUP\192_168_1_1\sql

:: 備份 本機 到 1_123 上日期 資料夾
XCOPY D:\SQL_BACKUP\VA \\%SERVER_NAME%\%SERVER_PATH%\%CUR-DRB% /D:%CUR-DRB-SQL% /K/E/Y/C/I/H
if '%errorlevel%' NEQ '0' exit /B

:: 刪上星期備份的資料夾
RD /S /Q \\%SERVER_NAME%\%SERVER_PATH%\%filename%

::斷掉原本連線
net use "\\%SERVER_NAME%" /delete

echo SQL_BY_WEEK_TO_1_123 完成備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log



REM 每周備份WEB_TO_1_100開始,先寫記錄時間 ===========================================================================

echo WEB_BY_WEEK_TO_1_100 開始備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

::重新設定路徑
set SERVER_NAME=192.168.1.100
set SERVER_PATH=backup\192_168_1_1\web

::重新連線新路徑
net use "\\%SERVER_NAME%" /user:lswin 1gnutat

:: 備份 來源端資料 到 目的端資料夾 日期 資料夾
XCOPY D:\WEB_BACKUP\%CUR-DRB% \\%SERVER_NAME%\%SERVER_PATH%\%CUR-DRB% /D/K/E/Y/C/I/H
if '%errorlevel%' NEQ '0' exit /B

:: 刪上星期備份的資料夾
RD /S /Q \\%SERVER_NAME%\%SERVER_PATH%\%filename%

echo WEB_BY_WEEK_TO_1_100 完成備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

REM 每周備份SQL_TO_1_100開始,先寫記錄時間 ===========================================================================

echo SQL_BY_WEEK_TO_1_100 開始備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log

::設定路徑
set SERVER_PATH=BACKUP\192_168_1_1\sql

:: 備份 D:\LSHEMRDB-Backup 到 1_100 上日期 資料夾
XCOPY D:\SQL_BACKUP\VA \\%SERVER_NAME%\%SERVER_PATH%\%CUR-DRB% /D:%CUR-DRB-SQL% /K/E/Y/C/I/H
if '%errorlevel%' NEQ '0' exit /B

:: 刪上星期備份的資料夾
RD /S /Q \\%SERVER_NAME%\%SERVER_PATH%\%filename%

::斷掉原本連線
net use "\\%SERVER_NAME%" /delete

REM 完成sql備份到 1_100
echo SQL_BY_WEEK_TO_1_100 完成備份時間 %date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,8% >> C:\BACKUPBAT\logs\%CUR-DRB%.log


REM 離開
REM pause
del /F /S C:\BACKUPBAT\logs\%filename%.log
exit /B


REM 如果不是週日,跳來這離開
:go_to_exit
REM pause
del /F /S C:\BACKUPBAT\logs\%filename%.log
exit /B



=======================================================
robocopy

可參考 : http://basuya.blogspot.tw/2009/12/robocopy.html 

/MAXAGE:n :: 最長的檔存在時間 - 排除早於 n 天/日期的檔。
/MINAGE:n :: 最短的檔存在時間 - 排除晚於 n 天/日期的檔。
 
備份前一天產生的資料 
robocopy d:\DB-Backup z:\DB-backup /mir /COPY:DT /FFT /MINAGE:1 /MAXAGE:2 
3/23 執行,會備份3/22 


列出完整的參數說明: 可以用「robocopy /?」 取得說明
下面列出完整的參數說明: (也可以用「robocopy /?」 取得說明)
------------------------------------------------------------------------------
              Usage :: ROBOCOPY source destination [file [file]...] [options]
                    source 來源:: 原始目錄(驅動器:\路徑或\\伺服器\共用\路徑)。
                destination目錄:: 目標目錄(驅動器:\路徑或\\伺服器\共用\路徑)。
                 file 文件:: 要複製的檔(名稱/萬用字元: 默認為 "*.*")。
------------------------------------------------------------------------------
複製選項:
------------------------------------------------------------------------------
                 /S :: 複製子目錄,但不複製空的子目錄。
                 /E :: 複製子目錄,包括空的子目錄。
             /LEV:n :: 僅複製原始目錄樹的前 n 層。
                 /Z :: 在可重新開機模式下複製檔。
                 /B :: 在備份模式下複製檔。
                /ZB :: 使用可重新開機模式;如果拒絕訪問,請使用備份模式。
            /EFSRAW :: 在 EFS RAW 模式下複製所有加密的檔。
      /COPY:複製標記:: 要複製的檔內容(預設為 /COPY:DAT)。
                       (複製標記: D=資料,A=屬性,T=時間戳記)。
                       (S=安全=NTFS ACL,O=所有者資訊,U=審核資訊)。
           /DCOPY:T :: 複製目錄時間戳記。
               /SEC :: 複製具有安全性的檔(等同於 /COPY:DATS)。
           /COPYALL :: 複製所有檔資訊(等同於 /COPY:DATSOU)。
            /NOCOPY :: 不複製任何檔資訊(與 /PURGE 一起使用生效)。
            /SECFIX :: 修復所有檔的檔安全性,即使是跳過的文件。
            /TIMFIX :: 修復所有檔的檔時間,即使是跳過的檔。
             /PURGE :: 刪除來源中不再存在的目的檔案/目錄。
               /MIR :: 鏡像目錄樹(等同於 /E 和 /PURGE)。
               /MOV :: 移動檔(複製後從源中刪除)。
              /MOVE :: 移動檔和目錄(複製後從源中刪除)。
     /A+:[RASHCNET] :: 將給定的屬性添加到複製檔。
     /A-:[RASHCNET] :: 從複製檔中刪除給定的屬性。
            /CREATE :: 僅創建目錄樹和長度為零的檔。
               /FAT :: 僅使用 8.3 FAT 檔案名創建目的檔案。
               /256 :: 關閉超長路徑(> 256 字元)支援。
             /MON:n :: 監視源;發現多於 n 個更改時再次運行。
             /MOT:m :: 監視源;如果更改,在 m 分鐘時間內再次運行。
      /RH:hhmm-hhmm :: 運行小時數 - 可以啟動新副本的時間。
                /PF :: 以每個檔(而不是每個步驟)為基礎檢查運行小時數。
             /IPG:n :: 套裝程式間的間距(ms),以釋放低速線路上的頻寬。
------------------------------------------------------------------------------
檔選擇選項:
------------------------------------------------------------------------------
                 /A :: 僅複製具有存檔屬性集的檔。
                 /M :: 僅複製具有存檔屬性的檔並重置存檔屬性。
    /IA:[RASHCNETO] :: 僅包含具有任意給定屬性集的檔。
    /XA:[RASHCNETO] :: 排除具有任意給定屬性集的檔。
  /XF 文件[文件]... :: 排除與給定名稱/路徑/萬用字元匹配的檔。
  /XD 目錄[目錄]... :: 排除與給定名稱/路徑匹配的目錄。
                /XC :: 排除已更改的文件。
                /XN :: 排除較新的檔。
                /XO :: 排除較舊的文件。
                /XX :: 排除多餘的檔和目錄。
                /XL :: 排除孤立的檔和目錄。
                /IS :: 包含相同檔。
                /IT :: 包含已調整的檔。
             /MAX:n :: 最大的檔大小 - 排除大於 n 位元組的檔。
             /MIN:n :: 最小的檔大小 - 排除小於 n 位元組的檔。
          /MAXAGE:n :: 最長的檔存在時間 - 排除早於 n 天/日期的檔。
          /MINAGE:n :: 最短的檔存在時間 - 排除晚於 n 天/日期的檔。
          /MAXLAD:n :: 最大的最後訪問日期 - 排除自 n 以來未使用的檔。
          /MINLAD:n :: 最小的最後訪問日期 - 排除自 n 以來使用的檔。
                       (If n < 1900 then n = n days, else n = YYYYMMDD date)。
                /XJ :: 排除接合點。(預設情況下通常包括)。
               /FFT :: 假設 FAT 檔時間(2 秒細微性)。
               /DST :: 彌補 1 小時的 DST 時間差。
               /XJD :: 排除目錄的接合點。
               /XJF :: 排除文件的接合點。
------------------------------------------------------------------------------
重試選項:
------------------------------------------------------------------------------
               /R:n :: 失敗副本的重試次數: 默認為 1 百萬。
               /W:n :: 兩次重試間的等待時間: 默認為 30 秒。
               /REG :: 將註冊表中的 /R:n 和 /W:n 保存為默認設置。
               /TBD :: 等待定義共用名稱稱(重試錯誤 67)。
------------------------------------------------------------------------------
日誌記錄選項:
------------------------------------------------------------------------------
                 /L :: 僅列出 - 不複製、添加時間戳記或刪除任何檔。
                 /X :: 報告所有多餘的文件,而不只是選中的檔。
                 /V :: 生成詳細輸出,同時顯示跳過的檔。
                /TS :: 在輸出中包含原始檔案的時間戳記。
                /FP :: 在輸出中包含檔的完整路徑名稱。
             /BYTES :: 以位元組列印大小。
                /NS :: 無大小 - 不記錄檔大小。
                /NC :: 無類別 - 不記錄檔類別。
               /NFL :: 無檔清單 - 不記錄檔案名。
               /NDL :: 無目錄清單 - 不記錄目錄名稱。
                /NP :: 無進度 - 不顯示已複製的百分比。
               /ETA :: 顯示複製檔的預期到達時間。
           /LOG:文件:: 將狀態輸出到日誌檔(覆蓋現有日誌)。
          /LOG+:文件:: 將狀態輸出到日誌檔(附加到現有日誌中)。
        /UNILOG:文件:: 以 UNICODE 方式將狀態輸出到日誌檔(覆蓋現有日誌)。
       /UNILOG+:文件:: 以 UNICODE 方式將狀態輸出到日誌檔(附加到現有日誌中)。
               /TEE :: 輸出到控制台視窗和日誌檔。
               /NJH :: 沒有作業標頭。
               /NJS :: 沒有作業摘要。
           /UNICODE :: 以 UNICODE 方式輸出狀態。
------------------------------------------------------------------------------
作業選項 :
------------------------------------------------------------------------------
       /JOB:作業名稱:: 從命名的作業檔中提取參數。
      /SAVE:作業名稱:: 將參數保存到命名的作業檔
              /QUIT :: 處理命令列後退出(以查看參數)。
              /NOSD :: 未指定原始目錄。
              /NODD :: 未指定目標目錄。
                /IF :: 包含以下檔。



20150422補充
7-zip 官方命令文件
https://7-zip.googlecode.com/hg/help-src/cmdline/index.htm 

備份的語法,這是可以的,20150422測試ok,排除App_Date, 符號 " 可能不用
7z a -tzip -xr!"inetpub\wwwroot\xxxxx\App_Data\*.*" F:\WEB_BACKUP\%CUR-DRB%\Inetpub_%CUR-DRB%.zip C:\Inetpub >> C:\backup_bat\logs\%CUR-DRB%.log
 

沒有留言:

張貼留言