文档章节

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

lyy549745
 lyy549745
发布于 07/21 00:13
字数 1286
阅读 15
收藏 0

expect脚本同步文件

  • 在一台机器上把文件同步到多台机器上
  • 自动同步文件 vim 4.expect 
[root@yong-01 sbin]# vim 4.expect

#!/usr/bin/expect
set passwd "20655739"
spawn rsync -av root@192.168.181.135:/tmp/12.txt /tmp/
expect {
"yes/no" { send "yes\r"}
"password:" { send $passwd\r}
}
expect eof


查看同步过程
[root@yong-01 sbin]# chmod a+x 4.expect 
[root@yong-01 sbin]# ./4.expect 
spawn rsync -av root@192.168.181.135:/tmp/12.txt /tmp/
The authenticity of host '192.168.181.135 (192.168.181.135)' can't be established.
ECDSA key fingerprint is SHA256:oYqovve1b2BwHDBYcFasCiiFzZTHJvKDbTGZAjmlMXc.
ECDSA key fingerprint is MD5:3d:f8:af:0d:85:48:db:2a:46:0e:68:5f:eb:43:3e:43.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '192.168.181.135' (ECDSA) to the list of known hosts.
receiving incremental file list
12.txt

sent 30 bytes  received 84 bytes  228.00 bytes/sec
total size is 5  speedup is 0.04
[root@yong-01 sbin]# ls /tmp/12.txt 
/tmp/12.txt
[root@yong-01 sbin]# ll /tmp/12.txt 
-rw-r--r-- 1 root root 5 7月  21 00:48 /tmp/12.txt
  • expect eof :只有spawn执行的命令结果才会被expect捕捉到,因为spawn会启动一个进程,只有这个进程的相关信息才会被捕捉到,主要包括:标准输入的提示信息,eof和timeout。

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

  • set timeout 定义超时时间(单位为 秒) -1 为永远不超时
  • 指定host和要同步的文件 vim 5.expect
[root@yong-01 sbin]# vim 5.expect 

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

  • 变量定义的文件地址,使用时,必须写绝对路径
  • 本机文件同步到远程机器上去: ./5.expect 192.168.181.135 "/tmp/12.txt" 
  • [root@yong-01 sbin]# ./5.expect 192.168.181.135 "/tmp/12.txt"
    spawn rsync -av /tmp/12.txt root@192.168.181.135:/tmp/12.txt
    sending incremental file list
    12.txt
    
    sent 79 bytes  received 31 bytes  220.00 bytes/sec
    total size is 5  speedup is 0.05
    expect: spawn id exp6 not open
        while executing
    "expect eof"
        (file "./5.expect" line 10)
    

     

构建文件分发系统

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

1、rsync.expect 内容

[root@yong-01 sbin]# vim rsync.expect

#!/usr/bin/expect
set passwd "20655739"
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 创建路径
  • 因为实现分发系统,肯定是因为需要分发的机器数量过大,所以,定义好了 文件 的 list 列表文件以后, 还需要配置 ip 的列表文件
  • 创建需要同步文件的列表文件
  • 创建需要同步IP地址的列表文件
  1. rsync.sh 内容
#!/bin/bash 
for ip in `cat /tmp/ip.list`
do
    echo $ip   
    ./rsync.expect $ip /tmp/file.list
done

执行过程
[root@yong-01 sbin]# sh -x rsync.sh
++ cat /tmp/ip.list
+ for ip in '`cat /tmp/ip.list`'
+ echo 192.168.181.135
192.168.181.135
+ ./rsync.expect 192.168.181.135 /tmp/file.list
spawn rsync -avR --files-from=/tmp/file.list / root@192.168.181.135:/
building file list ... done
root/

sent 114 bytes  received 15 bytes  258.00 bytes/sec
total size is 1051  speedup is 8.15
expect: spawn id exp6 not open
    while executing
"expect eof"
    (file "./rsync.expect" line 10)
+ for ip in '`cat /tmp/ip.list`'
+ echo 192.168.181.138
192.168.181.138
+ ./rsync.expect 192.168.181.138 /tmp/file.list
spawn rsync -avR --files-from=/tmp/file.list / root@192.168.181.138:/
root@192.168.181.138's password: 
building file list ... done
root/
root/shell/
root/shell/case.sh
tmp/
tmp/12.txt

sent 1257 bytes  received 59 bytes  2632.00 bytes/sec
total size is 1051  speedup is 0.80
  • 这个sh 的目的,就是遍历一下 ip列表文件中的 ip地址

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

  • 文件不存在,会报错

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

批量远程执行命令

  • exe.expect 内容
#!/usr/bin/expect
set host [lindex $argv 0]
set passwd "20655739"
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"
  • exe.sh 内容
#!/bin/bash
for ip in `cat ip.list`
do
    echo $ip
    ./exe.expect $ip "w;free -m;ls /tmp"
done

© 著作权归作者所有

共有 人打赏支持
lyy549745
粉丝 5
博文 86
码字总数 201530
作品 0
深圳
20.31 expect脚本同步文件;20.32 expect脚本指定host和要同步的文件;

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

主内安详
05/03
0
0
expect同步文件&expect指定host和要同步的文件&构建文件分发系统&批量远程执行命令

20.31 expect脚本同步文件 expect通过与rsync结合,可以在一台机器上把文件自动同步到多台机器上 编写脚本 注:expect eof的作用,可以为spwan所执行的命令提供足够的时间执行,不会马上退出...

影夜Linux
07/21
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
04/26
0
0
linux复盘:expect构建文件分发系统

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

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

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

Zhouliang6
07/21
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

HTTPS is easy

HTTPS is easy https://www.troyhunt.com/https-is-easy/ HTTPS is easy! In fact, it's so easy I decided to create 4 short videos around 5 minutes each to show people how to enable ......

openthings
28分钟前
0
0
bugList 2

用户端: 1. 上传文件时,当选择:彩色-A3-双面时,第二个图片有bug 应改为 和第一个图片的类型相同 2. 确认打印时,三个下拉选目前有bug 应改为:根据后台配置的商家,group by计算出不同城...

勇恒
31分钟前
2
0
keras cnn 网咯 mnist 分类

搭建貌似比tf是简单很多。。。。。 from keras.datasets import mnistfrom keras.utils import np_utilsfrom keras.models import Sequentialfrom keras.layers import Dense, Activat......

阿豪boy
34分钟前
0
0
解决 /var/run/nginx.pid failed

nginx: [error] open() "/var/run/nginx.pid" failed (2: No such file or directory) sudo nginx -c /etc/nginx/nginx.conf nginx -s reload...

驛路梨花醉美
35分钟前
0
0
nginx负载均衡-ssl原理-生成ssl密钥对-nginx配置ssl

nginx负载均衡: 1.创建配置文件 vim /usr/local/nginx/conf/vhost/load.conf #添加以下内容: upstream qq_com #名字自定义,借助此模块定义多个IP,后面...

ZHENG-JY
36分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部