最近公司部分客户的服务出现了本地mongodb数据丢失被盗的现象,前期经排查发现为远程木马病毒攻击导致(勒索病毒)。由于部分客户的网络状况不是很良好,服务直接暴露在公网。因此要将客户服务器产生的数据进行定期的本地备份。

由于之前接触的mongodb都是停留在增删改查中,没有深入研究过,通过分析mongodb安装包发现其自身存在备份的程序

mongodb sharded dump 备份速度慢_mongodb

该应用程序会将mongodb数据全部备份到同级目录并创建一个dump文件夹以存储。

双击执行是没有问题的,但是要把它做成一个Windows的计划任务,每日凌晨自动执行即可。

尝试写了一个脚本程序代码如下

@echo off

schtasks /create /tn "mongodbdump"  /tr D:\KKKKK\mongodb\bin\mongodump.exe  /sc DAILY /st 17:00 

echo 创建成功,请检查... 

pause

创建成功后可在Windows的任务计划程序库中看到,等待到时执行时,黑框一闪而过,但是数据并没有进行备份,后经查阅资料发现是计划任务的起始于属性为空导致的,起始于属性就相当于该程序的执行空间点击打开链接

mongodb sharded dump 备份速度慢_mongodb_02

然后发现,bat脚本中并没有 start in的命令,这就很头疼了。没有这个属性搞不来啊。然后我尝试手动创建计划任务,添加起始于属性,执行,备份成功!但是这样是不能交给客户使用的,还得想办法解决。后来发现,Windows的计划任务,除了通过bat脚本直接创建外,也可以通过导入xml文件来创建计划任务,因此我把已经能成功执行的计划任务导出为xml,

<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
  <RegistrationInfo>
    <Date>2018-02-26T17:25:43.0439384</Date>
    <Author>USER\user</Author>
    <URI>\Mongodbdump</URI>
  </RegistrationInfo>
  <Triggers>
    <CalendarTrigger>
      <StartBoundary>2018-02-26T23:59:00</StartBoundary>
      <Enabled>true</Enabled>
      <ScheduleByDay>
        <DaysInterval>1</DaysInterval>
      </ScheduleByDay>
    </CalendarTrigger>
  </Triggers>
  <Principals>
    <Principal id="Author">
      <UserId>S-1-5-21-3273072657-3804375192-1838619181-1001</UserId>
      <LogonType>InteractiveToken</LogonType>
      <RunLevel>LeastPrivilege</RunLevel>
    </Principal>
  </Principals>
  <Settings>
    <MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
    <DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
    <StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
    <AllowHardTerminate>true</AllowHardTerminate>
    <StartWhenAvailable>false</StartWhenAvailable>
    <RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
    <IdleSettings>
      <StopOnIdleEnd>true</StopOnIdleEnd>
      <RestartOnIdle>false</RestartOnIdle>
    </IdleSettings>
    <AllowStartOnDemand>true</AllowStartOnDemand>
    <Enabled>true</Enabled>
    <Hidden>false</Hidden>
    <RunOnlyIfIdle>false</RunOnlyIfIdle>
    <WakeToRun>false</WakeToRun>
    <ExecutionTimeLimit>PT72H</ExecutionTimeLimit>
    <Priority>7</Priority>
  </Settings>
  <Actions Context="Author">
    <Exec>
      <Command>D:\KKKKK\mongodb\bin\mongodump.exe</Command>
      <WorkingDirectory>D:\KKKKK\mongodb\bin</WorkingDirectory>
    </Exec>
  </Actions>
</Task>



然后重新编写bat脚本,采用导入xml文件的方式进行创建计划任务:

rem 开始执行定时任务创建
 
rem 查找备份命令的xml文件
 
for %%f in (D:\KKKKK\mongodb\bin\*.xml) do (
  rem 查找到文件后,导入xml为计划任务
  call :importfile "%%f"
)
exit /b 0
 
:importfile
rem 获取文件名称及绝对路径
set filename=%1
 
rem 开始创建计划任务
schtasks /create /tn "Mongodb备份" /xml %filename% 
echo on

pause

如此一来,执行bat脚本,计划任务创建成功,等待到时,黑框一闪,查看数据备份,成功!

mongodb sharded dump 备份速度慢_数据备份_03

当然,这里备份的位置为同级目录,还可以在脚本或者服务程序中添加定时任务来拷贝备份数据到其他文件路径或盘符下,以防数据误删。至于如何拷贝,这里就不再赘述了。比较简单。