mongodb自动备份怎么做?
Admin 2021-05-13 群英技术资讯 706 次浏览
数据备份的重要性不用多说,如果遇到数据丢失或者损坏的情况,备份数据能大大降低数据发生意外的损失,因此这篇文章就给大家介绍一下基于MongoDB实现自动备份的过程,有需要的朋友可以看看。
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 eof exit
总结
本文没什么难点,都是一些细节――
写出来主要是总结下踩到的坑,另外,expect是一款通用的提供自动交互的工具,用来实现ssh的自动登录、sftp的自动登录、mysql的自动登录等。脚本的套路都和本文展示的结构基本类似。
总结
以上就是关于mongodb实现自动备份过程的介绍,小编认为还是比较实用的,感兴趣的朋友可以参考,希望大家阅读完这篇文章能有所收获,更多mongodb自动备份内容可以关注其他相关文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
对于MongoDB的查询方法你了解多少呢?MongoDB的查询方法在MongoDB中是非常重要的,那么下面我们就和小编一起去看看MongoDB的查询方法是怎样的,代码是什么呢?
MongoDB Java 环境配置 在 Java 程序中如果要使用 MongoDB,你需要确保已经安装了 Java 环境及 MongoDB JDBC 驱动。 本章节实例适合 Mongo 3.x 以上版本。 你可以参考本站的Java教程来安装Java程序。现在让我们来检测你是否安装了 MongoDB JDBC 驱动。 首先你必须下载mongo jar包,
mongodb数据库安全怎样提高?做好数据的安全防护是很重要的,因此下面给大家介绍两个提高mongodb数据库安全系数的办法,分别是禁止外网访问和为数据库设置账号密码登录权限。
spark整合mongodb的方法是什么?一些朋友对于怎么实现spark整合mongodb不是和清楚,下面就给大家简单的介绍一下Spark 和spark整合mongodb的方法步骤。
这篇文章主要给大家分享MongoDB聚合的用处以及操作,小编觉得是比较挺实用的,因此分享给大家做个参考,感兴趣的朋友就继续往下看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008