加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 系统 > 正文

mongodb自动备份如何做?

发布时间:2022-03-06 05:33:21 所属栏目:系统 来源:互联网
导读:数据备份的重要性不用多说,如果遇到数据丢失或者损坏的情况,备份数据能大大降低数据发生意外的损失,因此这篇文章就给大家介绍一下基于MongoDB实现自动备份的过程,有需要的朋友可以看看。 MongoDB备份比较简单,只需用内置的 mongodump 即可,命令格式如
        数据备份的重要性不用多说,如果遇到数据丢失或者损坏的情况,备份数据能大大降低数据发生意外的损失,因此这篇文章就给大家介绍一下基于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
        写出来主要是总结下踩到的坑,另外,expect是一款通用的提供自动交互的工具,用来实现ssh的自动登录、sftp的自动登录、mysql的自动登录等。脚本的套路都和本文展示的结构基本类似。

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!