本文介绍: 免交互 expect 脚本操作 字符转换

一.Here Document 免交互

1. 交互的概念

交互:当计算机播放某多媒体程序的时候,编程人员可以发出指令控制该程序的运行,而不是程序单方面执行下去,程序在接受到编程人员相应的指令后而相应地做出反应。

 对于Linux操作系统中,有许多操作都会触及到交互(根据系统的指示做出相对应的操作满足操作者的需求),对于shell脚本的自动化运维,就要实现免交互来达到自动化运维的效果。

常用的交互程序:read,ftp,passwd,su,sudo,fdisk等等 

 cat 也可配合免交互的方式重定向输出到文件。

2.Here Doucument 的作用和格式

Here Document 的作用:

  • 使用I/O重定向的方式将命令列表提供给交互式程序
  • 标准输入的一种替代品

语法格式:

命令  << 开始标记

————-

————-

结尾标记

使用须知:

  • 标记可以使用任意合法字符,但开始标记与结尾标记需要保持一致。(常用标记EOF,使用其它字母也可以)
  • 结尾的标记后面不能有任何字符(包括空行)
  • 开头标记前后的空格会被省略掉

3.Here Document 的运用

3.1 cat 命令的读取

3.2 tee 命令

选项:

-a 内容追加到给定的文件而非覆盖
-i 忽略中断信号

tee 和 cat 的区别:

tee 直接生成文件,cat  > 需要导一下

3.3 read 命令

3.4 统计行数

3.5 passwd 用户修改密码

4.Here Document 变量的使用

Here Document也支持变量的使用。

如果标记之间有变量被使用,会先替换变量值。如果想要将一些内容写入文件,除了常规的方法外,也可以使用 Here Document。

如果写入的内容中包含变量,在写入文件时要先将变量替换成实际值,再结合cat命令完成输出。

4.1 交互内容中输出变量

#!/bin/bash

x="nihao china"

y=$(cat <<EOF
111
222
$x
EOF
)
echo "$y"

4.2 去除tab键影响

解决方法:

效果显著哦

4.3  : 多行注释

二.expect 实现免交互运用

1.expect 工具介绍

expect 是建立在 tcl 语言基础上的一个工具,常被用于进行自动化控制和测试,解决 shell 脚本中交互相关的问题。

需要安装两个软件包:expect,tcl。但是安装了expect后就会有tcl(yum解决依赖关系就安装了tcl)

建立在 tcl 语言基础上的一个工具,常被用于进行自动化控制和测试,解决 shell 脚本中交互相关的问题

2. 检测 expect 工具是否存在及安装

检查 expect 安装包:

[root@localhost ~]#rpm -q expect 
expect-5.45-14.el7_1.x86_64

检查依赖包tcl:

[root@localhost ~]#rpm -q tcl
tcl-8.5.13-8.el7.x86_64

安装下载 expect 工具:

[root@localhost ~]#yum install expect -y

3. expect 基本使用

3.1 脚本解释器的声明

3.2 spawn 启动进程并捕捉交互信息

 spawn 后面通常跟一个 Linux 执行命令,表示开启一个会话、启动进程,并跟踪后续交互信息(监控  捕捉)

3.3 expect 从进程接收字符串

  • 判断上次输出结果中是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回;
  • 只能捕捉由 spawn 启动的进程的输出;
  • 用于接收命令执行后的输出,然后和期望的字符串匹配

3.4 send 用于向进程发送字符串

  • 向进程发送字符串,用于模拟用户的输入;
  • 该命令不能自动回车换行,一般要加r (回车)或者n
方式一:
expect "密码" {send "abc123r"}     #同一行send部分要有{}

方式二:
expect "密码"  
send "abc123r"                    # 换行send部分不需要有{}


方式三:
expect 支持多个分支
expect          #只要匹配了其中一个情况,执行相应的send 语句后退出该expect 语句
只匹配一次
expect
{

{"密码1"  {send "abc123r"}
{"密码2"  {send "123123r"}
{"密码3"  {send "123456r"}

}

3.5 结束符 ( expect eof 或者 interact  只能二选一)

① expect eof

  • 表示交互结束,等待执行结束,退回到原用户,与 spawn 对应。
  • 比如切换到 root 用户,expect 脚本默认的是等待10s当执行完命令后,默认停留10s后,自动切回了原用户

② interact

  • 执行完后保持交互状态,把控制权交给控制台会停留在目标终端而不会退回到原终端,这个时候就可以手工操作了,interact 后的命令不起作用;
  • 使用 interact 会保持在终端而不会退回到原终端;

3.6 exp_continue

  • exp_continue 附加于某个 expect 判断项之后,可以使该项被匹配后,还能继续匹配该 expect 判断语句内的其他项。
  • exp_continue 类似于控制语句中的 continue 语句。表示允许 expect 继续向下执行指令。
  • 并行执行,exp_continue 前面的匹配如果有就执行,没有就不执行;但后面的一定会执行。

3.7 set  设置会话超时时间

expect 默认的超时时间是10秒,通过set 命令可以设置会话超时时间,若不限制超时时间则应设置为-1

3.8 send_users

表示回显命令,相当于 echo

3.9 接收参数

expect 脚本可以接受从 bash 命令行传递参数,使用 [lindex $argv n] 获得。其中你从0开始,分别表示第一个,第二个,第三个…..参数

4.expect 免交互的脚本运用

4.1 免交互传输文件

#!/usr/bin/expect

spawn scp /etc/passwd  192.168.44.30:/opt
#监控scp命令,出现scp命令开始捕捉屏幕内容

expect {
     "yes/no"  {send  "yesn";exp_continue}
     "password" {send "123n";}
}
#捕捉屏幕上的关键字,出现yes/no输入yes
#exp_continue 代表继续捕捉password
#出现 password 输入密码。 n  r 回车

expect eof
#代表结束

4.2 免交互修改用户密码

#!/usr/bin/expext

#脚本用于实现免交互修改lisi用户的密码

set timeout 2
#设置超时时间为2秒,默认情况是10秒

spawn passwd lisi
#spawn追踪后面指令产生的交互过程

expect "新的密码"
send "123123r"
expect "重新输入新的密码"
send "123123r"
#匹配交互过程中的提示信息
#send 相当于echo,传送在该交互过程中你的预设值

expect eof
#结束符

4.3 通过位置变量传入获取值,修改用户密码

#!/usr/bin/expect

#通过传参实现用户免交互修改密码的脚本

set timeout 2

set username [lindex $argv 0]
#脚本中第一个传入的参数赋予了前面的变量
set password [lindex $argv 1]
#脚本第二个传入的参数传入给变量

spawn passwd $username
expect "新的密码"
send "$passwordn"
expect "重新输入新的密码"
send "$passwordn"

expect eof
#结束符

4.4 嵌入式执行模式修改用户密码

嵌入执行模式,将expect过程融入Shell 当中,方便执行和处理;但是像ssh、su这种会切换环境的交互式命令一般不建议使用嵌入执行模式。

#!/bin/bash

username=$1
password=$2

/usr/bin/expect << EOF
set timeout 2
spawn passwd $username
expect "新的密码"
send "$passwordn"
expect "重新输入新的密码"
send "$passwordn"

expect eof

EOF

4.5 su 命令切换用户

#!/usr/bin/expect

set timeout 1

set username [lindex $argv 0]
set password [lindex $argv 1]

spawn su $username

expect "密码"
send "$passwordn"

expect "*]$"
send_user "$username 切换成功!"

interact

4.6 ssh 远程登录

#!/usr/bin/expect

set timeout 2
set hostname [lindex $argv 0]
set password [lindex $argv 1]

spawn ssh $hostname
expect {
 "No route to host" exit
#无法匹配的情况,直接退出
 "Connection refused" exit
#同上
 "(yes/no)" {send "yesn" ; exp_continue}
#交互式操作,选择yes同意进
 "password:" {send "$passwordn"}
}

interact

4.7 fdisk 分区操作

#!/usr/bin/expect

set timeout 2
set name [lindex $argv 0]

spawn fdisk $name
expect "获取帮助"
send "nr"
expect "Select"
send "pr"
expect "分区号"
send "r"
expect "起始"
send "r"
expect "Last"
send "+10Gr"
expect "命令"
send "wr"

interact

4.8 免交互远程创建用户

#!/bin/bash

net=192.168.44
password=123
iplist="
10
30
"
for i in $iplist
do
ip=$net.$i

/usr/bin/expect <<EOF

spawn ssh root@$ip

expect {
     "(yes/no)"
     {send "yesr";exp_continue}
     "*password"
     {send "$passwordr"}
}

expect "*]#" {send "useradd testn"}
expect "*]#" {send "echo 123 |passwd test --stdinr"}
expect "*]#" {send "exitr"}
expect eof
EOF
done

三.字符串处理

1. 取字符串的长度

2.跳过左边的字符

格式:

${var:offset}
#返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间(bash4.2后,允许为负值)
${var:offset:number}
#返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分

3.取字符串右边的字符

${var: -length}
#取字符串的最右侧几个字符,取字符串的最右侧几个字符, 注意:冒号后必须有一空白字符

4.掐头去尾

${var:offset:-length}
#从最左侧跳过offset字符,一直向右取到距离最右侧lengh个字符之前的内容,即:掐头去尾

5.取倒数的范围

${var: -length:-offset}
#先从最右侧向左取到length个字符开始,再向右取到距离最右侧offset个字符之间的内容,注意:-length前空格,并且length必须大于offset

6. 删左留右

#非贪婪模式   有一个就行
${var#*word}


#贪婪模式    全都要
${var##*word}


7.删右留左

#非贪婪模式
${var%word*}


#贪婪模式
${var%%word*}

8.查找替换

${var/pattern/substr}
${变量/搜索的字符串/修改的字符串}
#查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substr替换之



${var//pattern/substr}
#查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substr替换之



${var/#pattern/substr}
#查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substr替换之
#  在 此处  #代表开头


${var/%pattern/substr}
#查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substr替换之
# 在此处  % 代表结尾

9.大小写转换

${var^^}
#把var中的所有小写字母转换为大写


${var,,}
#把var中的所有大写字母转换为小写

原文地址:https://blog.csdn.net/qq_57093716/article/details/135951932

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_64291.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注