Shell Expect自动化交互(示例)

Shell Expect自动化交互

日常linux运维时,经常需要远程登录到服务器,登录过程中需要交互的过程,可能需要输入yes/no等信息,所以就用到expect来实现交互。

关键语法

❶[#!/usr/bin/expect]

这一行告诉操作系统脚本里的代码使用那一个shell来执行。这里的expect其实和linux下的bash、windows下的cmd是一类东西。 注意:这一行需要在脚本的第一行。

❷set

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

例如:set timeout 300 // 表示会话超时时间为300s

例如:set timeout -1 /设置/永不超时,常用设置

备注:为什么要设置超时时间,因为默认时间是10s,则在交互执行的过程中,很可能会断开,导致任务执行没完成就终止。我司的一个从远程ftp上同步文件的计划任务总是执行终止,后来设置了超时时间为-1就可以了。

❸spawn

spawn后面通常跟一个Linux执行命令,表示开启一个会话、启动进程,并追踪后续交互信息。

❹expect

只有spawn执行的命令的执行结果才被expect捕捉到,主要包括标准输入的提示信息、eof和timeout。等待命令提示信息的出现,也就是捕捉用户输入的提示:

➎send

发送需要交互的值,替代了用户手动输入内容;该命令不能自动回车换行,一般要加\r(回车)或者\n

expect "密码"{ send "abc123\r"} //同一行send部分要有{}

❻结束符expect eof/interact

expect eof

这个一定要加,与spawn对应表示捕获终端输出信息终止,类似于if....endif

interact

执行完成后保持交互状态,把控制权交给控制台,这个时候就可以手工操作了。如果没有这一句登录完成后会退出,而不是留在远程终端上。

PS:expect脚本必须以interact或expect eof结束,执行自动化任务通常expect eof就够了。

示例

在shell脚本中插入expect命令,格式为如下

示例1:22.sh创建文件夹脚本

|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| #!/bin/sh expect spawn ssh 10.1.1.196 expect password {send xxx\n} send cd /home/cg/hmf_app/test\r send mkdir newwork\r send exit\r expect eof EOF |

示例2:创建文件夹shell脚本

|----------------------------------------------------------------------------------------------------------------------------------------------|
| expect spawn ssh 10.1.1.196 expect password {send xxx\n} send cd /home/cg/hmf_app/test\r send mkdir newwork\r send exit\r expect eof EOF |

示例3:拷贝文件

|----------------------------------------------------------------------------------------------------------------------------|
| expect set timeout -1 spawn scp root@10.1.1.10:/data/package/casb/$casbzip ./ expect password {send xxx\n} expect eof EOF |

备注:

EOF

...

EOF

代表一段shell脚本

参考:Shell Expect自动化交互_shell脚本交互自动输入内容-CSDN博客

相关推荐
少妇的美梦7 小时前
logstash教程
运维
chen9457 小时前
k8s集群部署vector日志采集器
运维
chen9457 小时前
aws ec2部署harbor,使用s3存储
运维
東雪蓮☆12 小时前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
qq_2642208912 小时前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs
乌萨奇也要立志学C++13 小时前
【Linux】进程概念(二):进程查看与 fork 初探
linux·运维·服务器
雨落Liy13 小时前
Nginx 从入门到进阶:反向代理、负载均衡与高性能实战指南
运维·nginx·负载均衡
Yyyy48213 小时前
Nginx负载均衡集群实验步骤
运维·nginx·负载均衡
獭.獭.15 小时前
Linux -- 信号【上】
linux·运维·服务器
hashiqimiya15 小时前
centos配置环境变量jdk
linux·运维·centos