20.31 expect脚本同步文件;20.32 expect脚本指定host和要同步的文件;20.33 构建文件分发系统;20.34

简介:

20.31 expect脚本同步文件

自动同步文件

1. 同步远程机器hao2/tmp/12.txt文件 到本机/tmp/下:

[root@hao-01 ~]# vim 4.expect

添加内容:

#!/usr/bin/expect

set passwd "admin"

spawn rsync -av root@192.168.211.129:/tmp/12.txt /tmp/

expect {

"yes/no" { send "yes\r"}

"password:" { send "$passwd\r" }

}expect eof

2. 增加4.expect脚本x权限

[root@hao-01 ~]# chmod a+x 4.expect

3. 执行4.expect脚本(自动同步文件)

[root@hao-01 ~]# ./4.expect

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

1. 执行脚本需要:指定host(主机ip)和要同步的文件

[root@hao-01 ~]# vim 5.expect

添加内容:

#!/usr/bin/expect

set passwd "admin"

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

2. 增加5.expect脚本x权限

[root@hao-01 ~]# chmod a+x 5.expect

3. 执行5.expect脚本(执行一次只能同步一个文件!)

[root@hao-01 ~]# ./5.expect 192.168.211.128 "tmp/12.txt"

20.33 构建文件分发系统

shell项目-分发系统-构建文件分发系统

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

2. 实现思路首先要有一台模板机器,把要分发的文件准备好,然后只要使用expect脚本批量把需要同步的文件分发到目标机器即可。

3. 核心命令rsync -av --files-from=list.txt  /  root@host:/

文件分发系统的实现

1. 创建rsync.expect核心脚本:

(从本地/根目录 到远程/根目录)

[root@hao-01 ~]# vim rsync.expect

(远程ip机器密码需要和本地一致;也可以做用户认证,即可不用密码一致,安全)

添加内容:

#!/usr/bin/expect

set passwd "admin"

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

2. 创建本地同步文件列表文件

(本地同步远程机器文件;绝对路径)

[root@hao-01 ~]# vim /tmp/file.list

添加内容:

/tmp/12.txt

/root/1.txt

3. 创建远程机器ip列表文件

(远程ip机器密码需要和本地一致;也可以做用户认证,即可不用密码一致,安全)

[root@hao-01 ~]# vim /tmp/ip.list

添加内容:

192.168.211.129

127.0.0.1

4. 创建 rsync.sh循环脚本:

(对应指定: 同步到远程机器ip列表文件 本地同步文件列表文件)

[root@hao-01 ~]# vim rsync.sh

添加内容:

#!/bin/bash

for ip in `cat /tmp/ip.list`

do

    ./rsync.expect $ip /tmp/file.list

done

5. 增加rsync.sh脚本x权限

[root@hao-01 ~]# chmod a+x rsync.sh

6. 执行rsync.sh脚本

[root@hao-01 ~]# sh -x rsync.sh

20.34 批量远程执行命令

1. 创建exe.expect核心脚本:

[root@hao-01 ~]# chmod a+x exe.expect

添加内容:

#!/usr/bin/expect

set host [lindex $argv 0]

set passwd "admin"

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"

2. 增加exe.expec脚本x权限

[root@hao-01 ~]# chmod a+x exe.expec

3. 创建exe.sh脚本:

(设定 访问远程机器执行的命令)

[root@hao-01 ~]# vim exe.sh

#/bin/bash

for ip in `cat /tmp/ip.list`

do

./exe.expect $ip "ls"

done

4. 执行exe.sh脚本:

[root@hao-01 ~]# sh exe.sh

wKiom1nDYB3gnegRAABHRZeaatk934.png










本文转自 主内安详 51CTO博客,原文链接:http://blog.51cto.com/zhuneianxiang/1967454,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
SQL 关系型数据库 分布式数据库
利用 PolarDB PG 版向量化引擎,加速复杂 SQL 查询!完成任务领发财新年抱枕!
利用 PolarDB PG 版向量化引擎,加速复杂 SQL 查询!完成任务领发财新年抱枕!
137 14
|
6月前
职场新人:怎么做结构化汇报?
文章介绍了结构化汇报的基本逻辑和四种常用逻辑框架,帮助读者提升职场技能。
262 7
职场新人:怎么做结构化汇报?
|
7月前
|
传感器 人工智能 搜索推荐
数字孪生在医疗健康中的作用:重塑医疗体验与提升服务质量
数字孪生技术在医疗健康领域的应用正逐步展现出巨大潜力,通过构建患者的个性化数字模型,实现精准医疗、疾病预测、手术优化、设备仿真和患者管理,显著提升了医疗服务质量与患者体验。
|
10月前
|
人工智能 自然语言处理 算法
利用AI技术实现自动化文本
【8月更文挑战第31天】本文将介绍如何利用AI技术实现自动化文本摘要生成。我们将使用Python编程语言和自然语言处理库NLTK,通过一个简单的例子展示如何使用这些工具来提取文本的关键信息并生成摘要。通过学习本文,你将能够掌握基本的文本摘要生成方法,并了解如何将其应用于实际项目中。
|
10月前
|
机器学习/深度学习 TensorFlow 数据处理
分布式训练在TensorFlow中的全面应用指南:掌握多机多卡配置与实践技巧,让大规模数据集训练变得轻而易举,大幅提升模型训练效率与性能
【8月更文挑战第31天】本文详细介绍了如何在Tensorflow中实现多机多卡的分布式训练,涵盖环境配置、模型定义、数据处理及训练执行等关键环节。通过具体示例代码,展示了使用`MultiWorkerMirroredStrategy`进行分布式训练的过程,帮助读者更好地应对大规模数据集与复杂模型带来的挑战,提升训练效率。
291 0
|
10月前
|
网络架构
|
Python 容器
使用flet创建todo应用
使用flet创建todo应用
123 2
|
存储 缓存 安全
从软件和硬件角度去看内存
从软件和硬件角度去看内存
167 0
|
机器学习/深度学习 存储 弹性计算
阿里云服务器ECS架构ARM计算介绍
阿里云服务器ECS架构ARM计算介绍,ARM计算架构特性:ARM计算架构采用阿里云自研倚天710 ARM架构CPU,依托第四代神龙架构,提供稳定可预期的超高性能。同时通过芯片快速路径加速手段,完成存储、网络性能以及计算稳定性的数量级提升。基于ARM架构的实例规格,每一个vCPU都对应一个处理器的物理核心,具有性能稳定且资源独享的特点
489 0
|
存储 弹性计算 运维
阿里云容器镜像服务 | 学习笔记
快速学习阿里云容器镜像服务
阿里云容器镜像服务 | 学习笔记