20、15 构建文件分发系统

需求背景
对于大公司而言,肯定时不时会有网站或者配置文件更新,而且使用的机器肯定也是好多台,少则几台,多则几十甚至上百台。所以,自动同步文件是至关重要的。
实现思路
首先要有一台模板机器,把要分发的文件准备好,然后只要使用expect脚本批量把需要同步的文件分发到目标机器即可。
核心命令
rsync -av --files-from=list.txt / root@host:/
使用rsync 的 --files参数,可以实现调用文件里面的列表,进行多个文件远程传输,进而实现文件分发
文件分发系统的实现

1.rsync.expect 内容
vim rsync.expect

#!/usr/bin/expect
set passwd "123123a"
set host [lindex $argv 0]
set file [lindex $argv 1]
spawn rsync -avR --files-from=$file / root@$host:/   //这个地方定义了原目录和目标目录以跟目录开始
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof

chmod a+x rsync.expect
同步的路径,需要保证对方机器也有这个相同的路径,如果没有路径,需要使用 -R 创建路径
因为实现分发系统,肯定是因为需要分发的机器数量过大,所以,定义好了 文件 的 list 列表文件以后, 还需要配置 ip 的列表文件
创建需要同步文件的列表文件
创建需要同步IP地址的列表文件

文件list
vim /tmp/list.txt
/tmp/12.txt
/root/shell/01.sh

ip list
vim /tmp/ip.txt
192.168.179.129
127.0.0.1

rsync.sh 内容
#!/bin/bash 
for ip in `cat /tmp/ip.txt`
do
./rsync.expect $ip /tmp/list.txt
done

这个sh 的目的,就是遍历一下 ip列表文件中的 ip地址
最重要的,expect脚本 必须加入执行权限
文件不存在,会报错
分发系统还有一个重要的关键是,确保同步的机器的密码一致,否则将不能实现同步;所以这就存在一个弊端,一旦脚本暴露,将会让别人知道如何登陆你机器;当然也有对应的解决办法,那就是使用密钥认证,这样的话,自然在命令行业省去“输入密码< password:" { send "$passwd\r" } >''”和“定义密码< set passwd "123123a" >”的命令了
sh -x rsync.sh

7c0b00ed130bf28d743c9054ab54cbf6da7.jpg

  

转载于:https://my.oschina.net/u/3867322/blog/2208215

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值