专栏首页运维小白Linux基础(day76)

Linux基础(day76)

20.31 expect脚本同步文件

expect脚本同步文件

  • 在一台机器上把文件同步到多台机器上
  • 自动同步文件
#!/usr/bin/expect
set passwd "123456"
spawn rsync -av root@192.168.133.132:/tmp/12.txt /tmp/
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof  
  • expect eof :只有spawn执行的命令结果才会被expect捕捉到,因为spawn会启动一个进程,只有这个进程的相关信息才会被捕捉到,主要包括:标准输入的提示信息,eof和timeout。

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

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

  • set timeout 定义超时时间(单位为 秒) -1 为永远不超时
  • 指定host和要同步的文件
#!/usr/bin/expect
set passwd "123123a"
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
  • 变量定义的文件地址,使用时,必须写绝对路径

20.33 构建文件分发系统

构建文件分发系统

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

1、rsync.expect 内容

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

20.34 批量远程执行命令

批量远程执行命令

  • exe.expect 内容
#!/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"
  • exe.sh 内容
#!/bin/bash
for ip in `cat ip.list`
do
    echo $ip
    ./exe.expect $ip "w;free -m;ls /tmp"
done

扩展:

shell多线程

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 1.14 救援模式

    在centos6之前,有0-6七个级别 0 关机 (init 0) 1 单用户模式 2、3、4 命令行下的多用户模式 (在正常启动时,未安装图形界面进入的...

    运维小白
  • 10.11 Linux网络相关

    linux网络相关 ifconfig查看网卡ip(yum install net-tools) ifup ens33/ifdown ens33 设定虚拟网卡en...

    运维小白
  • 16.5/16.6/16.7 配置Tomcat虚拟主机

    16.5/16.6/16.7 配置Tomcat虚拟主机目录概要 vim /usr/local/tomcat/conf/server.xml 其中<Host>和<...

    运维小白
  • Java是如何实现自己的SPI机制的? JDK源码(一)

    这是【源码笔记】的JDK源码解读的第一篇文章,本篇我们来探究Java的SPI机制的相关源码。

    源码笔记
  • 人工智能"眼睛",摄像头调试经验笔记

    1.简介2.摄像头模组基本构造与工作原理2.1 基本构造2.1.1 镜头Lens2.1.2 IR Filter红外滤镜2.1.3 Sensor2.2 数据输出2...

    bigmagic
  • CV学习笔记(十二):图像金字塔

    尺度,顾名思义就是说图像的尺寸和分辨率。在我们进行图像处理的时候,会经常对源图像的尺寸进行放大或者缩小的变换,进而转换为我们指定尺寸的目标图像。在对图像进行放大...

    云时之间
  • CV学习笔记(十二):图像金字塔

    尺度,顾名思义就是说图像的尺寸和分辨率。在我们进行图像处理的时候,会经常对源图像的尺寸进行放大或者缩小的变换,进而转换为我们指定尺寸的目标图像。在对图像进行放大...

    云时之间
  • shell(二)

    The death of a dream is the day that you stop believing in the work it takes to ...

    小闫同学啊
  • 科学计算库Numpy——运算

    py3study
  • 分布式作业系统 Elastic-Job-Cloud 源码分析 —— 本地运行模式

    摘要: 原创出处 http://www.iocoder.cn/Elastic-Job/cloud-local-executor/

    芋道源码

扫码关注云+社区

领取腾讯云代金券