且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

Rsync + SSH + Expect 实现安全的集中的自动的备份

更新时间:2022-10-04 19:55:59

                        Rsync + SSH + Expect 实现安全的集中的自动的备份

 
请在下图上点击一下,就可以看到清晰的图片了,笔者不大会弄图片,请见谅。
 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