一、Here Document免交互
1.1免交互定义
1.2语法格式
1.3实例
示例1:使用 wc -l 命令后面直接跟文件名就可以统计文件内有多少行内容,将要统计的内容置于标记“EOF” 之间,直接将内容传给 wc -l 来统计。
示例2:通常使用 read 命令接收用户的输入值时会有交互过程,在EOF两个标记间可以输入变量值
示例3:使用 passwd命令设置密码
1.4Here Document 变量设定
示例1:在写入文件时会先将变量替换成实际值,再结合cat 命令完成写入
示例2:整体赋值给变量输出,然后通过echo命令将变量值打印出来,调用变量加上双引号会更好
示例3:在标记上添加双引号,关闭变量替换的功能
1.6多行注释
二、expect
2.1 expect 定义
2.2expect安装
2.3expect中相关命令
2.4实例
2.4.1免交互su切换用户
2.4.2免交互远程ssh脚本
1.4.3免交互scp脚本
使用I/O重定向的方式将命令列表提供给交互式程序
*
标准输入的一种替代品,可以帮助脚本开发人员不必使用临时文件来构建输入信息,而是直接就地 生产出一个文件并用作命令的标准输入,Here Document 可以与非交互式程序和命令一起使用
语法格式
命令 << 标记
....
输入内容
......
标记
注意事项
标记可以使用任意的合法字符(通用的字符是EOF)
1.
结尾的标记一定要顶格写,前面不能有任何字符(包括空格)
1.
结尾的标记后面也不能有任何字符(包括空格)
1.
开头标记前后空格会被省略掉
1.
单引号 变量双引号 —
[root@localhost ~]#wc -l <<EOF
> 1
> 2
> 3
> EOF
3
##read命令会有交互过程
[root@localhost ~]# read -p "请输入一个数字" ack
请输入一个数字8
[root@localhost ~]# echo $ack
8
###使用免交互,则EOF之间的值会变成变量i的参数
[root@localhost ~]# read i <<EOF
> hello
> EOF
[root@localhost ~]#echo $i
hello
[root@localhost ~]#passwd yxp <<EOF
> 123123
> 123123
> EOF
Here Document 也支持使用变量,如果标记之间有变量被使用,会先替换变量值。如 果想要将一些内容写入文件,除了常规的方法外,也可以使用 Here Document。如果写入 的内容中包含变量,在写入文件时要先将变量替换成实际值,在结合 cat 命令完成写入。
[root@localhost data]#vim eof1.sh
#!/bin/bash
file="yxp.txt"
var="park"
cat <<EOF >$file
I am going to the $var
EOF
[root@localhost data]#vim eof1.sh
#!/bin/bash
file="yxp1.txt"
var="park"
my=$(cat <<EOF >$file
I am going to the $var
EOF
)
echo $my
• Bash的默认注释是“/#”,该注释方法只支持单行注释: Here Document 的引入解决了多行注释的问题
• “:"代表什么都不做的空命令。中间标记区域的内容不会被执行,会被bash忽略掉,因此可达到批量注释的效果
#!/bin/bash
file="yxp2.txt"
var="park"
myvar=$(cat <<EOF >$file
I am going to the $var.
I will go to play with my friends.
I am very happy.
EOF
)
echo $myvar
###下面部分就被注释了不会显示
:<<EOF
echo "I am going to the $var"
echo "I am very happy."
EOF
是建立在tcl(tool command language)语言基础上的一个工具,常被用于进行自动化控制和测试,解决shell脚本中交互的相关问题
rpm -q expect
rpm -q tcl
yum install -y expect
脚本解释器
expect 脚本中首先引入文件,表明使用的事哪一种shell
*
/#!/usr/bin/expect
spawn 启动新的进程(监控,捕捉)
spawn后面通常跟一-个Linux执行命令,表示开启一个会话、启动进程,并跟踪后续交互信息 例: spawn passwd root
*
expect 从进程接收字符串
判断上次输出结果中是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回;
*
只能捕捉由spawn启动的进程的输出;
*
用于接收命令执行后的输出,然后和期望的字符串匹配
*
send 用于向进程发送字符串
向进程发送字符串,用于模拟用户的输入;
*
该命令不能自动回车换行,一般要加\r (回车)或者\n
*
exp_continue 匹配多个字符串在执行动作后加此命令
exp_ continue 类似于控制语句中的continue 语句。表示允许expect 继续向下执行指令
*
expect eof
表示交互结束,等待执行结束,退回到原用户,与spawn对应
*
比如切换到root用户,expect脚本默认的是等待10s当执行完命令后,默认停留10s后,自动切回了原用户
interact 允许用户交互
会停留在目标终端而不会退回到原终端,这个时候就可以手工操作了,interact后的命.令不起作用;
*
比如interact后添加exit,并不会退出root用户。而如果没有interact则登录完成后会退出,而不是留在远程终端上。
*
使用interact会保持在终端而不会退回到原终端;
*
set
expect 默认的超时时间是10秒,通过set 命令可以设置会话超时时间,若不限制超时时间则应设置为-1
例子: set time out 30
*
send_users
表示回显命令与echo相同
*
接收参数
expect 脚本可以接受从bash命令行传递参数,使用 [lindex $argv n]获得。其中你从0开始,分别表示第一个,第二个,第三个.....参数
*
例子:
set hostname [lindex $argv 0] 相当于hostname=$1
set password [lindex $argv 1] 相当于passswd=$2
set hostname [lindex $argv 0] 相当于hostname=$1
set password [lindex $argv 1] 相当于passswd=$2
[root@localhost opt]#vim expect.sh
#!/usr/bin/expect
#设置超时时间
set timeout 5
set hostname [lindex $argv 0]
#hostname=$1
set password [lindex $argv 1]
#password=$2
#开始追踪命令
spawn su $hostname
expect "密码:" {send "123123\n"}
#免交互执行,捕捉信息并匹配
expect "]#"
send_user "hello"
#把控制权交给控制台
interact
#expect eof
[root@localhost opt]#vim ssh.sh
#!/usr/bin/expect
#开启ssh命令,ssh后面跟要远程控制的IP地址
spawn ssh 192.168.59.105
expect {
"yes/no" { send "yes\n";exp_continue }
"password" { send "123123\n"}
}
interact
[root@localhost opt]#vim scp.sh
#!/usr/bin/expect
spawn scp /etc/passwd 192.168.59.105:/data
expect {
"yes/no" { send "yes\n";exp_continue }
"password: " { send "123123\n" }
}
expect eof
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/m0_51160032/article/details/121025586
内容来源于网络,如有侵权,请联系作者删除!