文档章节

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

影夜Linux
 影夜Linux
发布于 2018/07/21 00:55
字数 1482
阅读 11
收藏 0

20.31 expect脚本同步文件

expect通过与rsync结合,可以在一台机器上把文件自动同步到多台机器上

编写脚本

[root@linux-5 ~]# cd /usr/local/sbin
[root@linux-5 sbin]# vim 4.expect
#!/usr/bin/expect
set passwd "123456"
spawn rsync -av root@192.168.88.10:/root/1.txt /tmp/
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof

注:expect eof的作用,可以为spwan所执行的命令提供足够的时间执行,不会马上退出expect,从而导致命令尚未执行完毕而退出的情况(尤其是文件传输的命令);interact的作用可以使远程登录后保留登录状态

脚本授权

[root@linux-5 sbin]# chmod a+x !$
chmod a+x ./4.expect

执行脚本

[root@linux-5 sbin]# ./4.expect 
spawn rsync -av root@192.168.88.10:/root/1.txt /tmp/
receiving incremental file list
1.txt

sent 43 bytes  received 96 bytes  278.00 bytes/sec
total size is 6  speedup is 0.04
expect: spawn id exp6 not open
    while executing
"expect eof"
    (file "./4.expect" line 8)

结果验证

[root@linux-5 sbin]# cat /tmp/1.txt
12345

20.32 expect脚本指定host和要同步的文件

通过带参数的方式为指定的地址同步指定的文件

编写脚本

#!/usr/bin/expect
set passwd "123456"
set host [lindex $argv 0]   #第一个参数
set file [lindex $argv 1]   #第二个参数
spawn rsync -av $file root@$host:$file
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof

脚本授权

[root@linux-5 sbin]# chmod a+x 5.expect

执行脚本

[root@linux-5 sbin]# ./5.expect 192.168.88.10 /tmp/1.txt 
spawn rsync -av /tmp/1.txt root@192.168.88.10:/tmp/1.txt
sending incremental file list
1.txt

sent 96 bytes  received 35 bytes  262.00 bytes/sec
total size is 6  speedup is 0.05
expect: spawn id exp6 not open
    while executing
"expect eof"
    (file "./5.expect" line 10)

结果验证

[root@linux-10 ~]# cat /tmp/1.txt 
12345

20.33 构建文件分发系统

需求背景

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

实现思路

首先要有一台模板机器,把要分发的文件准备好,编写两个脚本,一个expect文件分发脚本,一个IP遍历脚本,将分发脚本嵌套在IP遍历脚本中,用IP遍历脚本为文件分发脚本提供IP参数以及需要同步的文件目录,再使用expect文件分发脚本批量把需要同步的文件分发到目标机器即可实现。

核心命令

rsync -av --files-from=list.txt / root@host:/

使用rsync 的 --files参数,可以实现调用文件里面的列表,进行多个文件远程传输,进而实现文件分发

构建文件分发系统

编写expect文件分发脚本

#!/usr/bin/expect
set passwd "123456"
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

同步的路径,需要保证对方机器也有这个相同的路径,如果没有路径,需要使用 -R 选项创建路径

编写IP遍历脚本

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

创建需要同步的文件的列表文件

vim /tmp/file.list
##将需要同步的文件的绝对路径写入列表文件中
/usr/local/sbin/1.sh
/usr/local/sbin/2.sh
/usr/local/sbin/3.sh
/root/23.txt

创建需要同步的IP地址的列表文件

vim /tmp/ip.list
192.168.88.10

脚本授权

[root@linux-5 sbin]# chmod a+x rsync.expect
[root@linux-5 sbin]# chmod a+x rsync.sh

脚本测试

[root@linux-5 sbin]# sh -x rsync.sh
++ cat /tmp/ip.list
+ for ip in '`cat /tmp/ip.list`'
+ echo 192.168.88.10
192.168.88.10
+ ./rsync.expect 192.168.88.10 /tmp/file.list
spawn rsync -avR --files-from=/tmp/file.list / root@192.168.88.10:/
building file list ... done
root/
root/23.txt
usr/local/
usr/local/sbin/
usr/local/sbin/01.sh
usr/local/sbin/02.sh
usr/local/sbin/03.sh

sent 647 bytes  received 101 bytes  1,496.00 bytes/sec
total size is 271  speedup is 0.36
expect: spawn id exp6 not open
    while executing
"expect eof"
    (file "./rsync.expect" line 10)

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

20.34 批量远程执行命令

实现原理

与批量分发类似,需要将远程执行命令脚本嵌套在IP遍历脚本中,由IP遍历脚本为远程执行命令脚本传递IP的参数和所需要执行的具体命令的参数。

编写远程执行命令脚本

vim exe.except
#!/usr/bin/expect
set host [lindex $argv 0]
set passwd "123456"
set cm [lindex $argv 1]
spawn ssh root@$host
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect "]*"
send "$cm\r"
expect "]*"
send "exit\r"

编写IP遍历脚本

vim exe.sh
##利用for循环遍历IP,传递给远程脚本相应参数,并在循环中执行远程脚本
#!/bin/bash
for ip in `cat /tmp/ip.list`
do
   ./exe.except $ip "w;ls"
done

脚本授权

[root@linux-5 sbin]# chmod a+x exe.except
[root@linux-5 sbin]# chmod a+x exe.sh

脚本测试

[root@linux-5 sbin]# sh -x exe.sh
++ cat /tmp/ip.list
+ for ip in '`cat /tmp/ip.list`'
+ ./exe.except 192.168.88.10 'w;ls'
spawn ssh root@192.168.88.10
Last login: Sat Jul 21 16:37:14 2018 from 192.168.88.5
[root@linux-10 ~]# w;ls
 16:45:52 up  2:18,  2 users,  load average: 0.00, 0.01, 0.05
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
root     pts/0    192.168.88.1     15:47   52:08   0.00s  0.00s -bash
root     pts/1    192.168.88.5     16:45    0.00s  0.00s  0.00s w
1.txt  23.txt  anaconda-ks.cfg  zabbix-release-3.2-1.el7.noarch.rpm

 

© 著作权归作者所有

共有 人打赏支持
影夜Linux
粉丝 3
博文 76
码字总数 127166
作品 0
杭州
运维
私信 提问
加载中

评论(1)

沉迷于编程的小菜菜
沉迷于编程的小菜菜
挺多的嘞
20.31 expect脚本同步文件;20.32 expect脚本指定host和要同步的文件;

20.31 expect脚本同步文件;20.32 expect脚本指定host和要同步的文件;20.33 构建文件分发系统;20.34 批量远程执行命令 20.31 expect脚本同步文件 自动同步文件 1. 同步远程机器hao2上/tmp/...

主内安详
2018/05/03
0
0
2018-4-27 18周2次课 分发系统-expect讲解(下)

20.31 expect脚本同步文件 ·自动同步文件 [root@localhost sbin]# chmod a+x 4.expect[root@localhost sbin]# ./4.expectspawn rsync -av root@192.168.65.129:/tmp/12.txt /tmp/root@192.......

alexis7gunner
2018/10/30
0
0
linux复盘:expect构建文件分发系统

需求:开发人员开发的代码发布到线上环境中(其实后面用到jenkins才是真正的98k) expect可以让我们实现自动登录远程机器,并且可以实现自动远程执行命令。当然若是使用不带密码的密钥验证同...

历经35天的选择
2018/02/10
13
0
expect脚本同步文件、expect脚本指定host和要同步的文件、构建文件分发系统

expect脚本同步文件 更改权限 执行脚本 查看执行结果 expect eof需要加上,作用是等脚本命令执行完再进行退出 expect脚本指定host和要同步的文件 更改权限,执行脚本 构建文件分发系统 需求背...

Zhouliang6
2018/07/21
0
0
20.31 expect脚本同步文件 20.32 expect脚本指定host和要同步的文件 20.33 构建文件分发系统 20.34 批量远程执行命令

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

夜归人8421
2018/04/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CSS 选择器参考手册

CSS 选择器参考手册 选择器 描述 [attribute] 用于选取带有指定属性的元素。 [attribute=value] 用于选取带有指定属性和值的元素。 [attribute~=value] 用于选取属性值中包含指定词汇的元素。...

Jack088
今天
1
0
数据库篇一

数据库篇 第1章 数据库介绍 1.1 数据库概述  什么是数据库(DB:DataBase) 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据...

stars永恒
今天
2
0
Intellij IDEA中设置了jsp页面,但是在访问页面时却提示404

在Intellij IDEA中设置了spring boot的jsp页面,但是在访问时,却出现404,Not Found,经过查找资料后解决,步骤如下: 在Run/Debug Configurations面板中设置该程序的Working Directory选项...

uknow8692
昨天
3
0
day24:文档第五行增内容|每月1号压缩/etc/目录|过滤文本重复次数多的10个单词|人员分组|

1、在文本文档1.txt里第五行下面增加如下内容;两个方法; # This is a test file.# Test insert line into this file. 分析:给文档后增加内容,可以用sed 来搞定;也可以用while do done...

芬野de博客
昨天
2
0
深入理解JVM—JVM内存模型

深入理解JVM—JVM内存模型 我们知道,计算机CPU和内存的交互是最频繁的,内存是我们的高速缓存区,用户磁盘和CPU的交互,而CPU运转速度越来越快,磁盘远远跟不上CPU的读写速度,才设计了内存...

onedotdot
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部