20.33 构建文件分发系统

构建文件分发系统

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

一、rsync.expect 内容bash

#!/usr/bin/expect
set passwd "123123a"
set host [lindex $argv 0]
set file [lindex $argv 1]
spawn rsync -av --files-from=$file / root@$host:/   //这个地方定义了原目录和目标目录以跟目录开始
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof
  • 同步的路径,须要保证对方机器也有这个相同的路径,若是没有路径,须要使用 -R 建立路径
  1. 由于实现分发系统,确定是由于须要分发的机器数量过大,因此,定义好了 文件 的 list 列表文件之后, 还须要配置 ip 的列表文件
  • 建立须要同步文件的列表文件
  • 建立须要同步IP地址的列表文件
  1. rsync.sh 内容

#!/bin/bash for ip in cat ip.list do echo $ip ./rsync.expect $ip list.txt done网站

  • 这个sh 的目的,就是遍历一下 ip列表文件中的 ip地址spa

  • 最重要的,expect脚本 必须加入执行权限.net

  • 文件不存在,会报错命令行

  • 分发系统还有一个重要的关键是,确保同步的机器的密码一致,不然将不能实现同步;因此这就存在一个弊端,一旦脚本暴露,将会让别人知道如何登录你机器;固然也有对应的解决办法,那就是使用密钥认证,这样的话,天然在命令行业省去“输入密码< password:" { send "$passwd\r" } >''”和“定义密码< set passwd "123123a" >”的命令了code