zoukankan      html  css  js  c++  java
  • 【bat】bat批处理异备文件、压缩文件(net use)

    sql server异备相关参考:https://blog.csdn.net/rznice/article/details/7742720

    1、压缩复制

    压缩本地文件,并把压缩后的文件复制到其他机器

    net use Z: \192.168.135.1share_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 FilesWinRAR" winRAR a %bath%%filename%.rar %bath%%filename%.bak copy %bath%%filename%.rar \192.168.135.1share_linux /Y net use \192.168.135.1share_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.217master_1_temp "AO%7Ro*AD35@bTa" /user:"7RoAdmin"' 

     删除net use 盘

    net use z: /delete /y

    2、数据库备份压缩

    写的是批处理的语句,每天调用,压缩删除原文件。

    首先写下路径,先将压缩软件的路径写入系统的环境变量里,加入到path中。比如将“C:Program FilesWinRAR”加入到path中。或者直接在bat中path="C:Program FilesWinRAR"。

    之后批处理中写好相应的处理命令:

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

    举个例子:    建立一个批处理BackFav.bat(名字可以随便起)文件内容:

    REM 这个批处理文件是用来自动备份我的收藏夹

    REM WinRAR <命令> -<开关1> -<开关N> <压缩文件> <文件> <@列表文件> <解压路径>

    "D:Program FilesWinRARWinRAR.exe" a -as -r -sfx -zsfxpara.txt -EP1 "d:my documentsFavorites.exe" "%USERPROFILE%Favorites"

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

    参数说明:

    a:                   添加指定的文件(源目录,这里是"%USERPROFILE%Favorites")和文件夹到压缩文件(目标文件,这里是"d:my documentsFavorites.exe")中。

    -as:                这是一个开关,指添加方式是“同步压缩文件内容”

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

    -sfx:               表示建立的是一个自解压文件

    -zsfxpara.txt: 从文件sfxpara.txt读取压缩文件注释,这注释有什么用后面解释

    -ep1:             表示不把路径%USERPROFILE%保存在压缩文件中

     注释文件的作用

    建立压缩文件的时候不光要考虑压缩那些文件,还要考虑怎么解压缩。通过注释文件可以向压缩包传递许多有用的信息。

    sfxpara.txt内容:

    PATH=%USERPROFILE%
    Silent=1

    例:


    "C:Program FilesWinRARRar.exe" a "g:aa.rar" "f:11.txt"     压缩"f:11.txt"到G盘,命名为“aa”
    "C:Program FilesWinRARRar.exe" d "g:aa.rar" "22.bat"        删除压缩包"g:aa.rar"中的"22.bat" 文件
    "C:Program FilesWinRARRar.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:logslogsOmsAdmin.2016-%month%-*.log) do "C:Program Files (x86)WinRARwinrar.exe" a -m5 -ibck D:logslog_%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:logslogs /s /D -30 /c "cmd /c del @file"
    参数说明:
    
    (1) forfiles通常用作对文件或文件夹的批处理,
    
      其中,/p:开始搜索的路径
    
           /s:递归到子目录
    
           /D:文件最后修改的日期时间 +/-数字
    
     
    
    3.复制文件
    
    xcopy D:fromlog_%curdate%.rar D:tolog_%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.217master_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% mp.vbs for /f "tokens=1,2,3* delims=-" %%i in (''cscript /nologo %tmp% mp.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.16FormStudio "88888888" /user:192.168.18.16administrator /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:WinRARwinrar.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 FilesMicrosoft SQL Server90Toolsinn
    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:shellatackup_log.txt
    set temp_file=C:shellatgameZoneName.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.92d$ "7RoAd#*(=-=)#!" /user:"7RoAdmin")
    
    ::mkdir
    c:
    cd C:Program FilesMicrosoft SQL Server90Toolsinn
    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 FilesMicrosoft SQL Server90Toolsinn
    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:shellddt_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[文件]       从文件读取压缩文件注释
  • 相关阅读:
    [ios][swift]提示框,并自动消失
    [ios][switf]页面跳转
    [ios][swift]UIButton
    [ios][swift]文本框UITextField用法
    html分割线
    html里 调整字间距
    php数字补零的两种方法
    PHP格式化数字和SMARTY格式化数字的方法
    CSS控制文字,超出部分显示省略号
    指定DIV局部刷新的简单实现,很简单,但是网上搜到的大部分都很复杂
  • 原文地址:https://www.cnblogs.com/gered/p/10283900.html
Copyright © 2011-2022 走看看