目录
1. 打开 控制面板-Windows工具(管理工具)-任务计划程序
- # backup.bat 脚本:
- set TODAY=%date:~0,4%-%date:~5,2%-%date:~8,2%_%time:~0,2%-%time:~3,2%-%time:~6,2%
- mkdir D:\keymanTech\backup\mongodb_backup\%TODAY%
- start cmd /c "cd /d C:\Program Files\MongoDB\Server\4.2\bin\ && mongodump.exe -h localhost:27017 --authenticationDatabase test -u root -p 123 -d test -o D:\keymanTech\backup\mongodb_backup\%TODAY%"
- start cmd /c "cd /d C:\Windows\system32 && ROBOCOPY D:\keymanTech\factorybi\dist\public\upload D:\keymanTech\backup\upload /R:5 /E /XO /NP >> D:\keymanTech\backup\upload_bak.logs"
-
- # 删除过期文件 del_backup.bak 脚本
- forfiles /p D:\keymanTech\backup\mongodb_backup\ /s /d -30 /m * /c "cmd /c del /q /f @path"
- # 日期格式 date 是年月日,time 是时分秒
- set TODAY=%date:~0,4%-%date:~5,2%-%date:~8,2%_%time:~0,2%-%time:~3,2%-%time:~6,2%
-
- # 创建当前时间的目录
- mkdir D:\keymanTech\backup\mongodb_backup\%TODAY%
-
- # 把 mongodb 备份到生成的当前日期目录中
- start cmd /c "cd /d C:\Program Files\MongoDB\Server\4.2\bin\ && mongodump.exe -h localhost:27017 --authenticationDatabase test -u root -p 123 -d test -o D:\keymanTech\backup\mongodb_backup\%TODAY%"
生成目录名称为:2022-11-18_11-03-23
但是上述指令不能生成如 .txt、.zip、.sql等后缀的文件,只能创建目录。还有就是时间戳格式不能写成:2022-11-18 11:03:23。有知道的同学欢迎在评论区指点一二,感谢!
- # 删除 D:\keymanTech\backup\mongodb_backup\ 目录下 前30天的文件
- forfiles /p D:\keymanTech\backup\mongodb_backup\ /s /d -30 /m * /c "cmd /c del /q /f @path"
自行指定的命令 "cmd /c del /q /f @path" 中:
如果想了解更多 forfile 命令信息,可以使用 forfiles /?
但是 forfile 命令只能删除文件,而不能删除目录文件夹。有知道的童鞋欢迎在评论区指正!
ROBOCOPY D:\keymanTech\factorybi\dist\public\upload D:\keymanTech\backup\upload /R:5 /E /XO /NP >> D:\keymanTech\backup\upload_bak.logs"
如果想了解更多 robocopy 命令信息,可以使用 robocopy /?
选择右边操作列中的“创建任务”:
就是设置脚本的触发频率。在触发器选项中点击新建:
选择“操作”选择,选择要执行的脚本文件:
前面步骤执行完即可创建成功,在任务计划程序库中可以看到刚刚创建的定时任务:
至此,可以根据编写的bat脚本与定时任务相结合做到自动备份、删除等功能!