前段时间,个人小程序 IT牧场 因服务器磁盘空间被占满,导致MongoDB挂了。清理了一些无用的数据后,重启MongoDB,竟然无法启动,一番折腾(20分钟)后,总算修复了。这让我意识到:虽然是个人小项目,但也必须定期备份啊,否则数据丢了很尴尬的说

碎碎念

•我不是MongoDB高手,之所以选择MongoDB,是因为需求不明确——MongoDB很适合不明确需求场景的开发。•个人对Elasticsearch更熟悉,Elasticsearch也很适合不定需求的业务开发;但个人服务器只有1G内存,用Elasticsearch得升级服务器,得花好多钱啊啊啊。

MongoDB备份比较简单,只需用内置的 mongodump 即可,命令格式如下:

mongodump -h {mongodb主机名}:{端口}  -u {账号} -p {密码} -d {数据库名称} -o {存储路径}

然而,笔者为MongoDB设置的密码是带有特殊字符的,例如 @#$\ 之类,直接以如上形式执行命令,会报错

所以笔者选择不带 -p 参数执行命令,即:

mongodump -h {mongodb主机名}:{端口}  -u {账号} -d {数据库名称} -o {存储路径}

然后,命令提示符会提示输入密码。例如:

# mongodump -h 127.0.0.1 -u user -d itmuch -o /tmp/somepathEnter password:

至此已实现MongoDB的备份。然而,手动备份还是挺麻烦的,怎么实现备份的自动化呢?

自动备份

正常来说,自动备份是比较简单的——只需将手动备份的命令做成Shell脚本,并设置定时任务即可。然而,笔者的场景,命令是需要交互式输入密码的啊!

怎么才能自动输入密码呢expect 登场了——一款提供自动交互的工具

安装expect

yum install -y expect

编写expect脚本

expect语法非常简单,和Shell几乎一样。笔者的脚本编写如下:

#!/bin/expect
# spawn是expect的语句,执行命令前需添加该字眼
set DATE [exec date "+%Y-%m-%d"]
set DIR /xxxxx/dbbak-$DATE
spawn rm -rf $DIR
spawn echo 'removing...$DIR'
spawn mongodump -h {host:port}  -u {user} -d {dbname} -o $DIR
# 交互获取是否返回password:关键字
expect "password:"
# 将密码发送过去,注意最后的换行不能少,否则得人工输入回车。
send "密码\r"
# 停留在远程控制台,没有这行就会直接返回本地控制台,而不等shell执行完
interact

注释很全面了,聪明的你阅读肯定没有压力。最终备份出来的文件会存放在 /xxxxx/dbbak-备份日期 目录中。

自动备份

笔者利用Linux定时任务实现自动执行。

crontab -e

在新窗口中添加如下内容:

0 0 1 * * ? /usr/bin/expect 上面expect shell的完整路径

原本以为这样就可以定时执行了,然而却无法正常执行

百度后,将脚本修改为如下,终于可以正常执行了。

#!/bin/expect
# spawn是expect的语句,执行命令前需添加该字眼
set DATE [exec date "+%Y-%m-%d"]
set DIR /xxxxx/dbbak-$DATE
spawn rm -rf $DIR
spawn echo 'removing...$DIR'
spawn mongodump -h {host:port}  -u {user} -d {dbname} -o $DIR
# 交互获取是否返回password:关键字
expect "password:"
# 将密码发送过去,注意最后的换行不能少,否则得人工输入回车。
send "密码\r"set timeout 120
expect eofexit

总结

本文没什么难点,都是一些细节——

•因为密码含有特殊字符,所以需要交互式输入密码;•因为要交互式输入密码,所以使用了expect

写出来主要是总结下踩到的坑,另外,expect是一款通用的提供自动交互的工具,用来实现ssh的自动登录、sftp的自动登录、mysql的自动登录等。脚本的套路都和本文展示的结构基本类似。

MongoDB自动备份全过程实录相关推荐

  1. Linux下MongoDB自动备份

    一.创建MongoDB备份目录 mkdir -p /data/mongodb_bak/mongodb_bak_now mkdir -p /data/mongodb_bak/mongodb_bak_li ...

  2. mongodb自动备份脚本

    #!/bin/bash # 要备份的数据库名'多个数据库用空格分开 # 备份文件要保存的目录 basepath="/data/backup/dump$(date +%Y%m%d%H%M%S) ...

  3. Mongodb 定时备份和恢复

    2019独角兽企业重金招聘Python工程师标准>>> 定时对数据库进行备份可以有效地保护数据 mongodump -h 127.0.0.1 --port 2777 -u ruiyi ...

  4. mysql 自动备份删除_mysql自动备份删除5天前的备份

    1.查看磁盘空间情况: # df -h 2.创建备份目录: 上面我们使用命令看出/home下空间比较充足,所以可以考虑在/home保存备份文件: cd /home mkdir backup cd ba ...

  5. mongodb数据库自动备份

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

  6. 用shell脚本实现MongoDB数据库自动备份

    一.创建MongoDB备份目录 用来存放数据 mkdir -p /data/mongodb_bak/mongodb_bak_now mkdir -p /data/mongodb_bak/mongodb ...

  7. mongodb数据库定时任务自动备份

    自行下载 yum install crontabs 创建文件夹 mkdir mb_data mkdir mb_data/crontab mkdir mb_data/mongodb mkdir mb_d ...

  8. Linux系统mongdb还原数据库,linux下mongodb数据库备份与还原

    MongoDb数据库备份还原 数据库迁移,可视化工具NoSQLBooster for MongoDB 付费版才具有数据导入功能.代价过高,索性采起命令行web 数据备份 备份命令mongodb mon ...

  9. MongoDB数据备份还原,及docker中MongoDB备份还原

    一: MongoDB数据备份 在Mongodb中我们使用mongodump命令来备份MongoDB数据.该命令可以导出所有数据到指定目录中. mongodump命令可以通过参数指定导出的数据量级转存的 ...

最新文章

  1. proftpd的搭建以及相关配置
  2. ASP.NET返回上一页面的实现方法
  3. cout、cerr、clog
  4. [Python图像处理] 十二.图像几何变换之图像仿射变换、图像透视变换和图像校正
  5. vue中如何进行Excel文件的下载
  6. c# uri.host_C#| Uri.FromHex()方法与示例
  7. Golang入门(1):安装与配置环境变量的意义
  8. C++ 20 还未发布,就已凉凉?
  9. android label关闭按钮,iOS弹出关闭按钮标签:“OK”还是“Okay”?
  10. Dbgview,本机内核打印的注册表配置
  11. 倒排索引的MapReduce实现
  12. java graphics2d旋转_反向Java Graphics2D缩放和旋转坐标
  13. Win7 系统下配置WinCE 5.0 模拟器网络环境
  14. SQL的删除语句delete(删除表中的数据)
  15. 关于验证身份证号码是否为真实有效
  16. 国产办公计算机,国内第一台纯国产计算机在重庆下线,芯片、系统全是纯国产...
  17. vue+cesium实现风场
  18. 通达信波段顶底指标公式,抓到真正顶底并且绝对精准可能吗?
  19. 设置input[type=number]不显示箭头
  20. 达芬奇大王的链表贪吃蛇(java)

热门文章

  1. [JVM]常用JVM工具使用
  2. 数据结构与算法书籍推荐
  3. 从tcp到netty(一)
  4. MUI多端发布开发指南(终于把MUI的使用场景说清楚了)
  5. LB 负载均衡的层次结构
  6. spring事务配置
  7. eclipse format的时候如何让@param后不换行
  8. 求解最长单调递增子串
  9. 一个商场营销经理的实习总结
  10. OpenCV 为图像转换为漫画效果