Shell编程之免交互
-
1.Here Document免交互Here
-
2.Document常规用法
-
3.Expect基本命令
-
4.Expect执行方式
-
5.Expect案例
6.总结
- Here Document免交互
Here Document概述
使用I/O重定向的方式将命令列表提供给交互式程序
标准输入的一种替代品
语法格式
命令 << 标记
...
...
标记
特殊字符“<<”在标记和命令之前,这样做的目的是将命令块的输出重定向到程序或命令的stadin。标记的选择要确保不会出现再其他地方,避免出现混淆;俩个标记之间的内容被当作事一个文件并作“命令”的标准输入。另外,Here Document也可以与非交互式程序和命令一起使用。
Here Document使用注意事项
标记可以使用任意合法字符
结尾的标记一定要顶格写,前面不能有任何字符
结尾的标记后面也不能有任何字符(包括空格)
开头标记前后的空格会被省略掉
2.Here Document常规用法
cat >> txt << EOF ##追加内容
创建yum源本地仓库
通过read命令接收输入并打印,输入值是俩个EOF标记之间的部分,也就是“10”,这将作为变量a的值
使用passwd给用户更改密码
变量设定
在写入文件时要先将变量替换成实际值,在结合cat命令完成写入
整体赋值给一个变量,然后通过echo命令将变量值打印出来
格式控制
关闭变量替换的功能,按照字符原本的样子输出,不做任何修改和替换
对标记使用’’包围,关闭变量替换
去掉每行之前的tab字符
在第一行的标记前加 - ,这个表示要抑制各行首页tab的作用
多行注释
bash的默认注释是#,盖住是方法支支持单行注释,在shell脚本的工作中,#右侧的任何字符串,bash都会将其忽略。Here Document的引入解决了多行注释的问题
“:”代表什么都不做的空命令。中间标记区域的内容不会被执行,会被bash忽略掉,一次可达到批量注释的效果。
: <<-EOF
this is IG
$one
EOF
批量注释格式
3.Expect基本命令
Expect概述
建立在tcl语言基础上的一个工具
常被用于进行自动化控制和测试
解决shell脚本中交互相关的问题
expect的安装
expect它是一个程序,所以它也是需要提前安装才可以使用的
rpm -q expect
rpm -q tcl
yum -y install expectl //yum或者光盘安装都可以
基本命令:
(1) 脚本解释器
expect脚本中首先引入文件,表明使用的是哪一个shell。
#!/usr/bin/expect
(2) spawn
spawn后面通常跟一个Linux执行命令,表示开启一个会话、启动进程,并跟踪后续交互信息。
例:spawn passwd root
(3) expect
判断上次输出结果中是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回;
只能捕捉由spawn启动的进程的输出;用于接收命令执行后的输出,然后和期望的字符串匹配
(4) send
向进程发送字符串,用于模拟用户的输入;该命令不能自动回车换行,一般要加\r (回车)或者\n
(5) 结束符expect eof
表示交互结束,等待执行结束,退回到原用户,与spawn对应。
比如切换到root用户,expect脚本默认的是等待10s,当执行完命令后,默认停留10s后,自动切回了原用户
方式一:
expect "密码"{ send "abc123\r" } #同一行send部分要有{}
方式二:
expect"密码"
send "abc123\r" #换行send部分不需要有{}
方式三:
expect支持多个分支expect #只要匹配了其中一个情况,执行相应的send语句后退出该expect语句
"密码1"{ send "abc123\r" }
"密码2"{ send "123456\r" }
"密码3"{ send "123123\r" }
interact
执行完成后保持交互状态,把控制权交给控制台,会停留在目标终端而不会退回到原终端,这个时候就可以手工操作了,interact后的命令不起作用,
比如interact后添加exit,并不会退出root用户。而如果没有interact则登录完成后会退出,而不是留在远程终端上。
使用interact会保持在终端而不会退回到原终端,比如切换到root用户,会一直在root用户状态下;比如ssh到另一服务器,会一直在目标服务器终端,而不会切回的原服务器。
注意: expect eof 与interact只能二选一。
(6) set
expect默认的超时时间是10秒,通过 set 命令可以设置会话超时时间,若不限制超时时间则应设置为-1。
例: set timeout 30
(7) exp continue
exp continue
附加于某个expect判断项之后,可以使该项被匹配后,还能继续匹配该expect-判断语句内的其他项。
exp_continue类似于控制语句中的continue语句。表示允许expect继续向下执行指令。
例如:下例将判断交互输出中是否存在yes/no 或*password。如果匹配 yes/no则输出 yes
并再次执行判断;如果匹配*password则输出abc123并结束该段expect语句。
expect {
"(yes/no)"{ send "yes\r";exp _continue; }
"*password" { set timeout 300;send "abc123\r"; }
}
注意:使用exp continue时,如果跟踪像passwd这样的输入密码后就结束进程的命令,expect(}外不要再加上expect eof
因为spawn进程结束后会默认向expect发送eof,会导致后面的expect eof执行报错
注:表示允许用户进行交互操作,一直保持会话连接
(8) send user
send_ user表示回显命令,相当于echo
(9) 接收参数
expect脚本可以接受从bash命令行传递的参数,使用[lindex $argvn]获得。
其中n从0开始,分别表示第一个,第二个,第三个..参数。
例:set hostname [ lindex $argv 0]
相当于hostname=$1
set password [ lindex $argv 1]
相当于password=$2
vim ceshi.sh
chmod +x ceshi.sh
./ceshi.sh
vim ceshi.sh
定义引用变量
用set关键字定义变量,变量名和变量的值之间用空格分开,其他用法与shell脚本一致
vim ceshi2.sh
还可以定义其他参数,例如超时时间,日志等
#超时时间
set timeout 20 //登陆超时多少秒退出
#开启日志文件
log_file test.log //日志记录操作
#显示信息
log_user 1 //1为屏幕输出信息,0为不输出
ssh免交互登录另外一种写法
#!/usr/bin/expect
set timeout 60
log_file test.log
log_user 1
set ip [ lindex $argv o]
set password [ lindex $argv 1]
spawn ssh root@${ip}
expect {
"(yes/no)"
{ send "yes\r"; exp_continue }
"*password"{ send "$password\r" }
interact
4.expect执行方式
嵌入执行模式,将expect过程融入shell 当中,方便执行和处理
在shell脚本中调用expect
创建用户并设置用户密码
vim ceshi3.sh
vim ceshi4.sh
5.Expect案例
利用expect 完成FTP登录过程
vim ftp.sh
保存退出执行脚本(注意,访问的机器需要下载vsftpd服务,关闭防火墙)
6.总结
Here Document使用方法
Expect基本命令
Expect使用方法
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤