一、创建MongoDB备份目录

用来存放数据

mkdir -p /data/mongodb_bak/mongodb_bak_now

mkdir -p /data/mongodb_bak/mongodb_bak_list

二、创建MongoDB数据库备份脚本

 

#!/bin/bash
#

DUMP=/usr/local/mongodb/bin/mongodump    #mongodump命令路


OUT_DIR=/data/mongodb_bak/mongodb_bak_now    
#临时备份目录 

TAR_DIR=/data/mongodb_bak/mongodb_bak_list    
#备份存放路径 

DATE=`date +%Y_%m_%d`   
#获取当前系统时间


DB_USER=myadmin    
#数据库账号


DB_PASS=******    
#数据库密码

DAYS=20    #DAYS=20代表删除20天前的备份,即只保留近20天的备份


TAR_BAK="mongodb_bak_$DATE.tar.gz"    
#最终保存的数据库备份文件 

cd $OUT_DIR

 

rm -rf $OUT_DIR/*

 

mkdir -p $OUT_DIR/$DATE

  
$DUMP -h 127.0.0.1:27017 -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" -o $OUT_DIR/$DATE   
#备份全部数据库


tar -zcvf $TAR_DIR/$TAR_BAK $
OUT_DIR/$DATE    #压缩为.tar.gz格式

 

find $TAR_DIR/ -mtime +$DAYS -delete   #删除20天前的备份文件

exit

给脚本加执行权限

[root@server1 mongodb_bak]# chmod +x MongoDB_bak.sh 

三、测试

运行脚本

[root@server1 mongodb_bak]# sh +x MongoDB_bak.sh

在目录下查看

将数据恢复:

[root@server1 mongodb_bak]# mongorestore -h 127.0.0.1:27017 -d cara2 /data/mongodb_bak/mongodb_bak_now/2018_07_25/cara

进入数据库查看:

数据正常,说明备份一切都是ok的!

四、添加定时任务

[root@server1 ~]# crontab -e

35 21 * * * /data/mongodb_bak/MongoDB_bak.sh   #每天18:00执行MongoDB数据库备份脚本

转载于:https://www.cnblogs.com/ExMan/p/10906863.html

用shell脚本实现MongoDB数据库自动备份相关推荐

  1. centos下MongoDB数据库自动备份(linux)

    centos下没有可视化工具,这个时候对MONGODB数据库进行备份,我们需要借助脚本和定时任务来进行. 1.创建MongoDB备份目录 我们创建一个当前备份和备份列表文件夹 mkdir -p /da ...

  2. mongodb数据库自动备份

    数据对我们现在应用系统越来越重要,这就驱使我们必须去做的一件事就是冗余备份,保证数据的完整性和可恢复性.既然如此重要,我们就必须去备份,但如果手动去做的话,不仅浪费时间,也可能导致数据丢失.最好的方式 ...

  3. svn数据库自动备份脚本

    创建一个存放备份数据的路径 mkdir /data/svnbak -p 采用shell脚本的方式实现自动备份 #vim backup.sh #!/bin/bash log="/data/sv ...

  4. oracle备份数据脚本,oracle数据库自动备份脚本

    ::通过exp命令导出远程机器(192.168.2.1)上指定服务(orcl)指定用户(pmis)及密码(pmis)的数据 ::运行该脚本的机器必须安装oracle @echo off @echo [ ...

  5. Linux oracle数据库自动备份自动压缩脚本代码

    Linux oracle数据库自动备份自动压缩脚本代码 Linux oracle数据库备份完成后可以自动压缩脚本代码. 复制代码代码如下: #!/bin/bash #backup.sh #edit: ...

  6. 数据库自动备份还原成新库脚本

    数据库自动备份还原成新库脚本 BACKUP DATABASE [源数据库名] TO DISK = N'G:\testbackup.bak' WITH COMPRESSION,NOUNLOAD , NA ...

  7. 数据库自动备份脚本使用

    数据库自动备份脚本使用 备份 Linux 请先在测试环境进行测试 编写备份脚本 根据情况调整以下内容中的参数,并保存为backup.sh并放置在数据库所在服务器上(位置无限制) echo '##### ...

  8. 【PostgreSQL实战】之实现数据库自动备份

    [原创,转载请说明]         我们在开发过程中,对于数据的要求格外严格,往往要做到数据库的备份.本文基于现实案例,实现Postgresql数据库备份,实现每日定时备份的功能.          ...

  9. db2数据备份到mysql_DB2数据库自动备份详解

    DB2数据库自动备份详解 由脱机备份转换为联机备份: 在db2CMD下执行 1.连接需要备份的数据库:db2 connect to数据库名称 2.修改自动数据库备份(AUTO_DB_BACKUP)参数 ...

最新文章

  1. ASP.NET 网站预编译概述
  2. python主要用来开发什么-python主要用于什么开发
  3. RedisTemplate方法的一些简单运用
  4. 蓄电池维护中的几大误区
  5. 深度解析利用ES6进行Promise封装总结
  6. python怎么输出表格中随机数_python 输出一个随机数
  7. asp.net关于如何准许api跨域访问
  8. Java程序设计语言基础02:Java中的基本数据类型和运算符
  9. 通过配置文件连接mysql_利用配置文件连接数据库
  10. 解决Jquery Kendo.xxx is not a function 的方法
  11. Cesium 模拟下雪
  12. 【毕设狗】【单片机毕业设计】基于单片机的智能衣柜设计–实物设计
  13. 速达登录服务器密码如何修改,登录速达软件口令忘记了进不去怎么弄
  14. 如何在虚拟机安装鸿蒙os,VirtualBox安装教程
  15. 欣赏的心态去发现生活中的美
  16. html5微信 红包源码,微信抢红包源码和模拟demo
  17. 微信支付--网页版-V3-(3)
  18. golang基础教程
  19. openstack placement
  20. Python语法之文件操作思维导图

热门文章

  1. 733. Flood Fill 图像渲染
  2. 2014\Province_C_C++_A\1 猜年龄
  3. Go 语言切片(Slice)
  4. 【MFC】可调整按钮位置的工具栏
  5. 职称不用计算机考试吗,中级职称计算机考试需要什么条件可不用考试
  6. python 读取word 题库_Python-docx 读取word.docx内容
  7. 在vscode上运行linux代码,在linux上安装VSCode
  8. OSTimeTick()函数解析
  9. nginx的函数调用
  10. GitFlow 工作流和Code Review教程