Rsync + SSH + Expect 实现安全的集中的自动的备份
请在下图上点击一下,就可以看到清晰的图片了,笔者不大会弄图片,请见谅。
因第一种方法(普通的备份方法)使用得比较多,所以就不在举例了。下面说说第二种方法(改进后的备份方法)的具体配置。
1、在备份中心上执行下列操作:
第一步:写一个BASH脚本,作具体的拷贝文件的工作,例如:
-bash-3.00# cat 181.sh
rsync -avz --rsh="ssh -l xx-rsync-user" \
--exclude-from=/opt/script/data/181/exclude_dirs \
xxx.xx.xxx.181:/usr/my_applications /opt/backup/xxx.xxx.xxx.181/
注:xx-rsync-user 是服务器xxx.xx.xxx.181上的一个普通权限用户,该用户只有对目
录/usr/my_applications的读权限。
第二步:写一个Expect脚本,调用第一步的BASH脚本,目的是给BASH脚本输入密码,例如:
-bash-3.00# cat 181.exp
#!/usr/bin/expect -f
#
spawn date "+%Y-%m-%d %H:%M"
expect "#"
spawn /opt/script/prod/181.sh
expect "password:" { send "<
用户xx-rsync-user的密码>
\n" }
expect ".*\@.*#"
第三步:建立一个crontab,调用第二步的Expect脚本,以定时自动备份,例如:
10 * * * * /opt/script/prod/181.exp >> /opt/script/data/181/181.log
2. 在需要备份资料的服务器上执行下列操作:
第一步:登录到服务器xxx.xx.xxx.181上去,建立用户xx-rsync-user,并授予其对/user/my_applications目录的只读权限;
如果有其它的服务器需要备份,那么重复上述步骤就OK了。
本文转自zkjian517 51CTO博客,原文链接:http://blog.51cto.com/zoukejian/56678