mongo自動備份指令碼和恢復

2021-07-26 02:23:31 字數 1915 閱讀 9760

一、建立mongodb備份目錄

mkdir -p /data/mongodb_bak/mongodb_bak_now

mkdir -p /data/mongodb_bak/mongodb_bak_list

二、新建mongodb資料庫備份指令碼(/data/mongodb_bak/mongodb_bak.sh)

指令碼如下:

#!/bin/bash

#backup mongodb

#mongodump命令路徑

dump=/usr/local/mongodb/bin/mongodump

#臨時備份目錄

out_dir=/data/mongodb_bak/mongodb_bak_now

#備份存放路徑

tar_dir=/data/mongodb_bak/mongodb_bak_list

#獲取當前系統時間

date=`date +%y_%m_%d`

#資料庫賬號

db_user=user

#資料庫密碼

db_pass=123

#days=15代表刪除15天前的備份,即只保留近15天的備份

days=15

#最終儲存的資料庫備份檔案

tar_bak="mongodb_bak_$date.tar.gz"

cd $out_dir

rm -rf $out_dir/*

mkdir -p $out_dir/$date

#備份全部資料庫

$dump -h 15.62.32.112:27017 -u $db_user -p $db_pass --authenticationdatabase "admin" -o $out_dir/$date

#壓縮為.tar.gz格式

tar -zcvf $tar_dir/$tar_bak $out_dir/$date

#刪除15天前的備份檔案

find $tar_dir/ -mtime +$days -delete

exit

三、修改檔案屬性,使其可執行

chmod +x mongodb_bak.sh

四、修改/etc/crontab,新增計畫任務

vi /etc/crontab

#每星期六晚上20:30開始執行

mongodb

資料庫

備份指令碼

30 20 * * 6 root /data/mongodb_bak/mongodb_bak.sh 

附錄:mongodb資料庫恢復

#恢復全部資料庫

mongorestore -u $db_user -p $db_pass --authenticationdatabase "admin" --noindexrestore --dir /data/mongodb_bak/mongodb_bak_now/2016_12_17/

#恢復單個資料庫

mongorestore -u $db_user -p $db_pass --authenticationdatabase "admin" --noindexrestore -d dbname --dir /data/mongodb_bak/mongodb_bak_now/2016_12_17/dbname

部分引數說明

--drop引數:恢復資料之前刪除原來的資料,避免資料重複

--noindexrestore引數:恢復資料時不建立索引

--dir引數:資料庫備份目錄

-d引數:後面跟要恢復的資料庫名稱

mongo 備份恢復

在mongo2.2.2版本中,mongodump的collections檔案,會同步生成乙個metadata.json檔案。這與之前的版本不同。目前檢視到的該json檔案中只包含了索引資訊。該資訊在mongorestore時會使用到,恢復完畢資料後,會建立索引。但該json檔案中不包含分片資訊,所以...

mongo備份恢復(單機和複製集)

邏輯匯出,可以作做跨版本和公升級匯出 mongoexport uroot p port 27021 d test c t1 authenticationdatabase admin o service t1.json 匯出csv 格式 f 後跟列名 j 開啟併發匯入 mongoexport uroo...

Mongo03 備份與恢復

使用mongoexport命令,將乙個collection匯出為json格式或csv格式的檔案。從mongodb4.2開始,mongoexport就不再隨著mongodb一起安裝了,需要單獨安裝,各平台安裝位址在這裡。要注意,linux和macos系統中,需要將工具拷貝到 path環境變數的目錄,也...