一、建立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環境變數的目錄,也...