Rsync + SSH + Expect 实现安全的集中的自动的备份
 
请在下图上点击一下,就可以看到清晰的图片了,笔者不大会弄图片,请见谅。
<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" /><?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

因第一种方法(普通的备份方法)使用得比较多,所以就不在举例了。下面说说第二种方法(改进后的备份方法)的具体配置。
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了。