需求背景
对于大公司而言,肯定时不时会有网站或者配置文件更新,而且使用的机器肯定也是好多台,少则几台,多则几十甚至上百台。所以,自动同步文件是至关重要的。
实现思路
首先要有一台模板机器,把要分发的文件准备好,然后只要使用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