批处理备份文件夹、并删除指定日期前的过期文件夹
(2019-02-24 15:26:46)分类: 运维 |
批处理备份文件夹、并删除指定日期前的过期文件夹
https://blog.csdn.net/u011481543/article/details/50674094
在服务器管理中,会经常用到数据备份以及删除过期备份数据的业务。
以下代买片段实现备份数据文件夹,并删除指定天数之前的过期备份数据。
本例系统时间格式为YYYY-MM-DD
backup.bat
@echo off
rem 备份今日数据
echo Today is te:~0,10%
set sou_dir="C:\Program Files\MySQL\MySQL Server
5.6\data"
set aim_dir="C:\sqlBack\te:~0,10%\"
echo sou_dir is %sou_dir%
echo aim_dir is %aim_dir%
md aim_dir
xcopy /e /y /h %sou_dir% %aim_dir%
rem 计算指定天数之前的日期
set DaysAgo=5
rem 假设系统日期的格式为yyyy-mm-dd
call :DateToDays te:~0,4% te:~5,2% te:~8,2% PassDays
set /a PassDays-=ysAgo%
call :DaysToDate %PassDays% DstYear DstMonth DstDay
set DstDate=%DstYear%-%DstMonth%-%DstDay%
echo ysAgo% days ago is:%DstDate%
rem rd命令删除5天前的文件
rem /S 表示删除该目录下所有遍历的子目录和文件
rem /Q 删除目录时不提示确认,直接删除
rd /s /q C:\sqlBack\%DstYear%-%DstMonth%-%DstDay%
goto :eof
:DateToDays %yy% %mm% % days
setlocal ENABLEEXTENSIONS
set yy=%1&set mm=%2&set dd=%3
if 1%yy% LSS 200 if 1%yy% LSS 170 (set yy=20%yy%) else (set
yy=19%yy%)
set /a dd=100%%0,mm=100%mm%%0
set /a z=14-mm,z/=12,y=yy+4800-z,m=mm+12*z-3,j=153*m+2
set /a j=j/5+dd+y*365+y/4-y/100+y/400-2472633
endlocal&set %4=%j%&goto :EOF
:DaysToDate ys% yy mm dd
setlocal ENABLEEXTENSIONS
set /a
a=%1+2472632,b=4*a+3,b/=146097,c=-b*146097,c/=4,c+=a
set /a
d=4*c+3,d/=1461,e=-1461*d,e/=4,e+=c,m=5*e+2,m/=153,dd=153*m+2,dd/=5
set /a
dd=-dd+e+1,mm=-m/10,mm*=12,mm+=m+3,yy=b*100+d-4800+m/10
(if %mm% LSS 10 set mm=0%mm%)&(if % LSS 10 set
dd=0%)
endlocal&set %2=%yy%&set %3=%mm%&set %4=%&goto
:EOF
后使用定时任务执行此脚本即可
---------------------
Forfiles命令删除指定天数以前的文件或文件夹
https://blog.csdn.net/Smasegain/article/details/46759267
一.命令说明
forfiles命令可以方便的对批量文件进行筛选和批量处理,本次来学习这个命令是因为一个备份策略需求。命令帮助信息如下:
FORFILES [/P pathname] [/M searchmask] [/S]
描述:
参数列表:
特别说明:
{+|-} "yyyy-mm-dd":表示其上一次修改日期大于等于(+),或小于等于(-)指定的日期;
{+|-}
dd(范围:0-32768):表示上次修改日期大于等于当前日期加dd指定的天数(+),或小于等于当前日期减指定的天数(-),默认为加号
示例:
二.使用案例
本次备份需要保留某个路径下相关文件或文件夹31天,则命令如下(删除31天以前的test开头的所有文件和文件夹):
if条件表示:如果是文件夹则采用rmdir删除,如果是文件则用del命令强制删除。
---------------------
后一篇:在局域网中隐藏自己