【bat】bat批處理異備文件、壓縮文件(net use)


sql server異備相關參考:https://blog.csdn.net/rznice/article/details/7742720

1、壓縮復制

壓縮本地文件,並把壓縮后的文件復制到其他機器

net use Z: \\192.168.135.1\share_linux a123456! /user:chaoqun.guo
set bath=c:\backup\
set today=%date:~0,4%%date:~5,2%%date:~8,2%
::%date:~0,4%,表示從第0下標開始獲取4位長度的值 set db_name=test set filename=%db_name%%today% path="C:\Program Files\WinRAR" winRAR a %bath%%filename%.rar %bath%%filename%.bak copy %bath%%filename%.rar \\192.168.135.1\share_linux /Y net use \\192.168.135.1\share_linux /delete

 在sql server中操作net use

EXEC sp_configure 'show advanced options',1;
RECONFIGURE WITH OVERRIDE;
EXEC sp_configure 'xp_cmdshell',1;
RECONFIGURE WITH OVERRIDE
EXEC master.dbo.xp_cmdshell 'net use x: \\219.129.239.217\master_1_temp "AO%7Ro*AD35@bTa" /user:"7RoAdmin"' 

 刪除net use 盤

net use z: /delete /y

 

 

2、數據庫備份壓縮

寫的是批處理的語句,每天調用,壓縮刪除原文件。

首先寫下路徑,先將壓縮軟件的路徑寫入系統的環境變量里,加入到path中。比如將“C:\Program Files\WinRAR\”加入到path中。或者直接在bat中path="C:\Program Files\WinRAR\"。

之后批處理中寫好相應的處理命令:

rar a -df %filename%.rar %filename%.dmp

 

舉個例子:    建立一個批處理BackFav.bat(名字可以隨便起)文件內容:

REM 這個批處理文件是用來自動備份我的收藏夾

REM WinRAR <命令> -<開關1> -<開關N> <壓縮文件> <文件> <@列表文件> <解壓路徑\>

"D:\Program Files\WinRAR\WinRAR.exe" a -as -r -sfx -zsfxpara.txt -EP1 "d:\my documents\Favorites.exe" "%USERPROFILE%\Favorites"

===================================================

參數說明:

a:                   添加指定的文件(源目錄,這里是"%USERPROFILE%\Favorites")和文件夾到壓縮文件(目標文件,這里是"d:\my documents\Favorites.exe")中。

-as:                這是一個開關,指添加方式是“同步壓縮文件內容”

-r:                  表示“包含子文件夾”

-sfx:               表示建立的是一個自解壓文件

-zsfxpara.txt: 從文件sfxpara.txt讀取壓縮文件注釋,這注釋有什么用后面解釋

-ep1:             表示不把路徑%USERPROFILE%保存在壓縮文件中

 

 注釋文件的作用

建立壓縮文件的時候不光要考慮壓縮那些文件,還要考慮怎么解壓縮。通過注釋文件可以向壓縮包傳遞許多有用的信息。

sfxpara.txt內容:

PATH=%USERPROFILE%\
Silent=1

例:


"C:\Program Files\WinRAR\Rar.exe" a "g:\aa.rar" "f:\11.txt"     壓縮"f:\11.txt"到G盤,命名為“aa”
"C:\Program Files\WinRAR\Rar.exe" d "g:\aa.rar" "22.bat"        刪除壓縮包"g:\aa.rar"中的"22.bat" 文件
"C:\Program Files\WinRAR\Rar.exe" d "g:\aa.rar" "ABC"           刪除壓縮包"g:\aa.rar"中的"ABC" 文件夾

 

 

批量壓縮復制:

1.壓縮指定的部分文件

復制代碼
@echo off

set year=%date:~0,4% 

set month=%date:~5,2% 

set day=%date:~8,2% 

set curdate=%year%%month%%day% 

for %%i in (D:\logs\logs\OmsAdmin.2016-%month%-*.log) do "C:\Program Files (x86)\WinRAR\winrar.exe" a -m5 -ibck D:\logs\log_%curdate%.rar %%i
復制代碼
參數說明:

(1) for語句支持通配符找文件,例如“OmsAdmin.2016-%month%-*.log”

(2) for語法: for %%i in 集合 do 命令(%%i)

(3) winrar語法:winrar a -m5 -ibck 生成的壓縮文件存儲路徑 被壓縮文件

      其中,a : 壓縮(e:解壓)

    -m5:按照第5等級最大程度壓縮

           -ibck:后台運行

 

2.刪除過期備份文件

forfiles /p D:\logs\logs /s /D -30 /c "cmd /c del @file"
參數說明:

(1) forfiles通常用作對文件或文件夾的批處理,

  其中,/p:開始搜索的路徑

       /s:遞歸到子目錄

       /D:文件最后修改的日期時間 +/-數字

 

3.復制文件

xcopy D:\from\log_%curdate%.rar D:\to\log_%curdate%.rar

 

 

 sql server中,調用批處理與net use

/*
在 sql server中調用 net use
  EXEC sp_configure 'show advanced options',1;
  RECONFIGURE WITH OVERRIDE;   EXEC sp_configure 'xp_cmdshell',1;   RECONFIGURE WITH OVERRIDE   EXEC master.dbo.xp_cmdshell 'net use x: \\219.129.239.217\master_1_temp "AO%7Ro*AD35@bTa" /user:"7RoAdmin"' 
*/



CREATE PROCEDURE [dbo].[Delete_File] @day NVARCHAR(3), @url NVARCHAR(100) AS BEGIN DECLARE @sql NVARCHAR(MAX),@result INT EXEC xp_fileexist 'C:\DEL.bat', @result OUTPUT --檢查文件DEL.bat存在 IF @result=1 EXEC xp_cmdshell 'del C:\DEL.bat' IF object_id('test','U')IS NOT NULL --檢查test表是否存在 DROP TABLE test SET @sql='@echo off setlocal enabledelayedexpansion Rem 取'+@day+'天之前的日期,取回放入變量riqi echo wscript.echo dateadd("d",-'+@day+',date) >%tmp%\tmp.vbs for /f "tokens=1,2,3* delims=-" %%i in (''cscript /nologo %tmp%\tmp.vbs'') do set y=%%i&set m=%%j&set d=%%k if %m% LSS 10 set m=0%m% if %d% LSS 10 set d=0%d% set riqi=%y%%m%%d% set "mulu='+@url+'" for /f "eol= skip=4 tokens=1,4" %%a in (''dir /a-d /tw "%mulu%"^|find /v ^"字節^"'') do ( set delrq=%%a set delrq=!delrq:-=! if !delrq! lss %riqi% ( del /q "%mulu%\%%~nxb" ) ) pause' select @sql a INTO test --將批處理腳本放入test表 EXEC xp_cmdshell 'bcp "select top 1 a from test" queryout C:\DEL.bat -c -T -S127.0.0.1,2433' --將批處理文件導出到C盤根目錄下 DROP TABLE test --刪除test表 EXEC xp_cmdshell 'C:\DEL.bat'--調用批處理文件 END

 

3、參考文件

--開啟xp_cmdshell,一次性
--sp_configure 'show advanced options',1
--reconfigure
--go
--sp_configure 'xp_cmdshell',1
--reconfigure
--go

--服務器D盤根目錄放winrar文件夾
--運行本sql:局域網共享文件夾存放生成的今天的備份文件,如果存在昨天的備份文件壓縮成功后刪除源文件,留壓縮文件
--解壓密碼為123
--替換msdb為你要備份的數據庫,文件局域網共享文件夾用戶名密碼ip或者計算機名

exec master..xp_cmdshell 'net use v: \\192.168.18.16\FormStudio "88888888" /user:192.168.18.16\administrator /y'

declare @filename varchar(200)
set @filename='v:\msdb'+convert(varchar,getdate(),112)+'.bak'  --設置備份文件的路徑和文件名
print @filename
backup database[msdb] to disk=@filename with 
NOINIT,NOUNLOAD,NAME='backup',NOSKIP,STATS=10,NOFORMAT  --執行備份

DECLARE @file varchar(200),
@retval   int, 
@param1   int,
@s varchar(200)
set @s='v:\msdb'+convert(varchar,getdate()-1,112)+'.bak'
set @file='D:\WinRAR\winrar.exe a -ep -m5 -p123 -df v:\msdb'+convert(varchar,getdate()-1,112)+'.rar v:\msdb'+convert(varchar,getdate()-1,112)+'.bak'  --將壓縮備份文件並刪除源文件的winrar命令行命令
EXECUTE   @retval=master..xp_fileexist @s,   @param1   OUTPUT   
IF   @param1   =   0
PRINT   'File   does   not   exist!' 
ELSE 
exec master..xp_cmdshell @file  --執行命令

exec master..xp_cmdshell 'net use v: /delete'

4.我的實踐

 

::insert db record
c:
cd C:\Program Files\Microsoft SQL Server\90\Tools\binn\
sqlcmd -A -Q"set nocount on;insert into db_mart..ddtupload_log(count_date) values(getdate())"


::init 
set dir=Db_Tank_Back
if exist F:\%dir% (set disk=F:\) else if exist E:\%dir% (set disk=E:\) else (set disk=D:\)

set old_filename=Db_Tank_Copy%date:~9,1%.bak
set new_filename=Db_Tank_Copy_%date:~0,4%%date:~5,2%%date:~8,2%.7z
set log_file=C:\shell\bat\backup_log.txt
set temp_file=C:\shell\bat\gameZoneName.txt
set path=%disk%%dir%\
echo %date%%time%>>%log_file%


::compress
::cd d:\ddt_tool\
d:
cd d:\ddt_tool\
7za.exe a %path%%new_filename% %path%%old_filename%
if exist %path%%new_filename% (echo compress success >>%log_file%) else (echo compress fail>>%log_file%)

::net use
if exist T:\ (@echo T disk ok) else (net use T: \\192.168.221.92\d$ "7RoAd#*(=-=)#!" /user:"7RoAdmin")

::mkdir
c:
cd C:\Program Files\Microsoft SQL Server\90\Tools\binn\
sqlcmd -A -Q"set nocount on;select '香港易游(1-2-4)' from db_gms..v_gameZoneName_Version;">%temp_file%
for /f "skip=2" %i in (%temp_file%) do set mkdir=%i
if exist t:\Db_Tank_Back\%mkdir% (@echo t:\%mkdir% ok) else (mkdir t:\Db_Tank_Back\%mkdir%)
cd \


::copy file
set new_path=t:\Db_Tank_Back\%mkdir%\
copy %path%%new_filename% %new_path% /y
if exist %new_path%%new_filename% (echo backup success >>%log_file%
c:
cd C:\Program Files\Microsoft SQL Server\90\Tools\binn\
sqlcmd -A -Q"set nocount on;update db_mart..ddtupload_log set isok = 1, upload_date = getdate() where convert(char(10),count_date,120) = convert(char(10),getdate(),120);"
) else (echo backup fail >>%log_file%)

 

pause

 

 

5.快速把bat腳本安裝成定時任務

/*
--ddt_db_backup_install.bat

@echo off
color 2
echo.
echo ----------------- ddt_db_backup_install  --------------------
echo ----------------- ddt_db_backup_install -------------------- > install.log 
echo.

schtasks /delete /TN ddt_db_backup /F
schtasks /delete /TN ddt_db_bakcup /F
schtasks /create /ru SYSTEM /tn "ddt_db_backup" /tr "C:\shell\ddt_db_bakcup.bat" /sc daily /st 06:10:00 /F

IF ERRORLEVEL 1 (ECHO Error: ddt_db_backup install error
ECHO Error: ddt_db_backup install error >> install.log 2>&1
goto error)
echo OK
echo OK >> install.log 2>&1

:ok
echo.
echo ------------------- Install Success ---------------------
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
goto end

:error
echo.
echo.
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
exit 1

:end
exit


*/

/*
--ddt_db_backup.bat
--add the code for delete override files

if exist F:\Db_Tank_Back (set data_path=F:\Db_Tank_Back) else if exist E:\Db_Tank_Back (set data_path=E:\Db_Tank_Back) else (if exist D:\Db_Tank_Back (set data_path=D:\Db_Tank_Back) )
forfiles /p %data_path% /s /m *.7z /d -7 /c "cmd /c del @path"

*/

 

附: 壓縮參數

 

用法:     rar <命令> -<開關 1> -<開關 N> <壓縮文件> <文件...>
               <@列表文件...> <解壓路徑\>

<注釋>
a             添加文件到壓縮文件
c             添加壓縮文件注釋
cf            添加文件注釋
ch            更改壓縮文件參數
cw            寫入壓縮文件注釋到文件
d             刪除壓縮文件中的文件
e             解壓壓縮文件到當前目錄
f             刷新壓縮文件中的文件
i[參數]=<> 在壓縮文件中查找字符串
k             鎖定壓縮文件
l[t,b]        列出壓縮文件[技術信息,簡潔]
m[f]          移動到壓縮文件[僅對文件]
p             打印文件到標准輸出設備
r             修復壓縮文件
rc            重建丟失的卷
rn            重命名壓縮文件
rr[N]         添加數據恢復記錄
rv[N]         創建恢復卷
s[名字|-]     轉換壓縮文件為自解壓格式或反之
t             測試壓縮文件
u             更新壓縮文件中的文件
v[t,b]        詳細列出壓縮文件[技術信息,簡潔]
x             用絕對路徑解壓文件

<開關>
-             停止掃描
ac            壓縮或解壓后清除存檔屬性
ad            添加壓縮文件名到目標路徑
ag[格式]      使用當前日期生成壓縮文件名
ao            添加具有存檔屬性的文件
ap<路徑>      添加路徑到壓縮文件中
as            同步壓縮文件內容
av            添加用戶身份校驗 (僅注冊版)
av-           禁用用戶身份校驗
c-            禁用注釋顯示
cfg-          禁用讀取配置
cl            名稱轉換為小寫
cu            名稱轉換為大寫
df            壓縮后刪除文件
dh            打開共享文件
ds            對固實壓縮文件禁用名稱排序
e[+]<屬性>    設置文件排除和包括屬性
ed            不添加空目錄
en            不添加"壓縮文件結束"標志
ep            從名稱中排除路徑
ep1           從名稱中排除基本目錄
ep2           展開為完整路徑
ep3           擴展路徑為包含盤符的完全路徑
f             刷新文件
hp[密碼]      同時加密文件數據和文件頭
id[c,d,p,q]   禁用信息顯示
ieml[地址]    郵寄壓縮文件
ierr          發送所有消息到標准錯誤設備
ilog[名稱]    把錯誤寫到日志文件 (僅注冊版)
inul          禁用所有消息
ioff          完成一個操作后關閉 PC 電源
isnd          啟用聲音
k             鎖定壓縮文件
kb            保留損壞的已解壓文件
m<0..5>       設置壓縮級別(0-存儲...3-默認...5-最大)
mc<參數>      設置高級壓縮參數
md<大小>      以KB為單位的字典大小(64,128,256,512,1024,2048,4096 or A-G)
ms[ext;ext]   指定存儲的文件類型
mt<線程>      設置線程數
n<文件>       僅包括指定文件
n@            從標准輸入設備讀取要包括的文件名稱
n@<列表>      在指定列表文件包括文件
o+            覆蓋已存在文件
o-            不覆蓋已存在文件
oc            設置 NTFS 壓縮屬性
or            自動重命名文件
os            保存 NTFS 流
ow            保存或恢復文件所有權和組
[密碼]        設置密碼
p-            不詢問密碼
r             包含子目錄
r0            僅包含通配符名稱的子目錄
ri<P>[:<S>]   設置優先級 (0-默認,1-最小..15-最大) 和休眠時間(毫秒)
rr[N]         添加數據恢復記錄
rv[N]         創建恢復卷
s[<N>,v[-],e] 創建固實壓縮文件
s-            禁用固實壓縮文件
sc<chr>[obj] 指定字符集
sfx[名稱]     創建自解壓文件
si[名稱]      從標准輸入設備讀取數據
sl<大小>      處理小於指定大小的文件
sm<大小>      處理大於指定大小的文件
t             壓縮后測試文件
ta<日期>      添加日期 <日期> 后修改的文件,日期格式 YYYYMMDDHHMMSS
tb<日期>      添加日期 <日期> 前修改的文件,日期格式 YYYYMMDDHHMMSS
tk            保留原始壓縮文件時間
tl            設置壓縮文件時間為最新時間
tn<時間>      添加 <時間> 以后的文件
to<時間>      添加 <時間> 以前的文件
ts<m,c,a>[N] 保存或恢復文件時間(修改,創建,訪問)
u             更新文件
v             自動檢測創建卷的大小或者列出所有的卷
v<大小>[k,b] 創建卷大小=<大小>*1000 [*1024, *1]
vd            創建卷前清除磁盤內容
ver[n]        文件版本控制
vn            使用舊樣式卷命名方案
vp            每卷之前暫停
w<路徑>       指定工作目錄
x<文件>       排除指定的文件
x@            從標准輸入設備讀取要排除的文件名
x@<列表>      排除指定列表文件中的文件
y             假設對全部詢問都回答是
z[文件]       從文件讀取壓縮文件注釋

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM