MongoDB自动备份全过程实录

MongoDB自动备份全过程实录

2019年05月10日 16:44:08 zl1zl2zl3 阅读数 12mysql

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

碎碎念mongodb

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

MongoDB备份比较简单,只需用内置的 mongodump 便可,命令格式以下:数据库

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

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

因此笔者选择不带 -p 参数执行命令,即:服务器

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

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

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

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

自动备份

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

怎么才能自动输入密码呢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的自动登陆等。脚本的套路都和本文展现的结构基本相似。

相关文章
相关标签/搜索