1. 程式人生 > >Windows中新增Mongodb定時備份任務(採用bat指令碼匯入xml計劃任務的方式)

Windows中新增Mongodb定時備份任務(採用bat指令碼匯入xml計劃任務的方式)

最近公司部分客戶的服務出現了本地mongodb資料丟失被盜的現象,前期經排查發現為遠端木馬病毒攻擊導致(勒索病毒)。由於部分客戶的網路狀況不是很良好,服務直接暴露在公網。因此要將客戶伺服器產生的資料進行定期的本地備份。

由於之前接觸的mongodb都是停留在增刪改查中,沒有深入研究過,通過分析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的任務計劃程式庫中看到,等待到時執行時,黑框一閃而過,但是資料並沒有進行備份,後經查閱資料發現是計劃任務的起始於屬性為空導致的,起始於屬性就相當於該程式的執行空間點選開啟連結


然後發現,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指令碼,計劃任務建立成功,等待到時,黑框一閃,檢視資料備份,成功!


當然,這裡備份的位置為同級目錄,還可以在指令碼或者服務程式中新增定時任務來拷貝備份資料到其他檔案路徑或碟符下,以防資料誤刪。至於如何拷貝,這裡就不再贅述了。比較簡單。