shell(构建文件分发系统)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell(构建文件分发系统)相关的知识,希望对你有一定的参考价值。

1. 需求背景
对于大公司而言,肯定时不时会有网站或者配置文件更新,而且使用的机器肯定也是好多台,少则几台,多则几十甚至上百台。所以,自动同步文件是至关重要的。

2. 实现思路
首先要有一台模板机器,把要分发的文件准备好,然后只要使用expect脚本批量把需要同步的文件分发到目标机器即可。
3. 核心命令
rsync -av --files-from=list.txt  /  [email protected]:/
4. 文件分发系统的实现
vim  rsync.expect

#!/usr/bin/expect
set passwd "123456"
set host [lindex $argv 0]
set file [lindex $argv 1]
spawn rsync -av --files-from=$file / [email protected]$host:/
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof

(vim ip.list vim file.list  创建ip和文件列表)

 

vim rsync.sh

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

 

5. 命令批量执行脚本
vim exe.expect

#!/usr/bin/expect
set host [lindex $argv 0]
set passwd "123456"
set cm [lindex $argv 1]

spawn ssh [email protected]$host

expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect "]*"
send "$cm\r"
expect "]*"
send "exit\r"

vim exe.sh

#!/bin/bash
for ip in `cat ip.list`
do
echo $ip
./exe.expect $ip "w;free -m;ls /tmp"
done

以上是关于shell(构建文件分发系统)的主要内容,如果未能解决你的问题,请参考以下文章

Shell项目-分发系统-expect

expect脚本同步文件指定host和要同步的文件构建文件分发系统批量远程执行命令

expect脚本同步文件expect脚本指定host和要同步的文件构建文件分发系统批量远程执行

分发系统:构建简易文件分发系统

2.2-构建简易文件分发系统

strive_tan shell编程实战2-分发系统