Expext概述
Expect是建立在tcl基础上的一个工具,Expect是用来自动化控制和测试的工具。主要解决shell脚本中不可交互的问题。有助于大规模的系统运维工作。在日常的运维与开发中,常常需要运城登录到服务器,然而登录的过程却是个需要交互的过程,可能会要输入yes/no等信息,使用Expect脚本即可实现免交互操作。
Expect安装
挂载光盘
制作本地YUM源
执行安装命令
yum install expect -y
基本命令
send
向进程发送字符串,用于模拟用户的输入,该命令不能自动回车换行,一般要加\r (回车)。
expect
expect的一个内部命令,判断上次输出结果里是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回。只能捕捉由spawn启动的进程的输出。
spawn
启动进程,并跟踪后续交互信息
interact
执行完成后保持交互状态,把控制权交给控制台
Timeout
指定超时时间,过期则继续执行后续指令
单位:秒
timeout -1 为永不超时
默认的timeout是10秒
exp_continue
允许expect继续向下执行指令
send_user
回显命令,相当于的echo输出
$arvg 参数数组
Expect脚本可以接受从bash传递的参数。可以使用[lindex $arvg n]获得,n从0开始,分别表示第一个,第二个,第三个为参数...参数
Expect脚本必须以interact或expect ecof结束,执行自动化任务通常expect eof就够了
expect eof实在等待结束标志。由spawn启动的命令在结束时会产生一个eof标记,expect eof即在等待这个标记
Expect语法
单分支语法
expect "passwd:" {send"mypasswd\r";}
多分支语法
expect"aaa"{send"AAA\r"} expect"aaa"{send"AAA\r"} expect"aaa"{send"AAA\r"} //Send命令不具备回车换行功能,一般要加\或\n
expect{ "aaa"{send"AAA\r"} "bbb"{send"BBB\r"} "ccc"{send"CCC\r"} } //只要匹配上了任何一个,执行项硬的send语句后退出该expect语句
expect{ "aaa"{send"AAA";exp_continue} "bbb"{send"BBB";exp_continue} "ccc"{send"CCC"} } //exp_continue表示继续后面的匹配,若匹配上了aaa,执行完send语句后还要继续往下匹配bbb
-re 参数表示匹配正则表达式
Expect执行方式
1.直接执行
案例演示:
SSH登录
首次登陆
正常登录
连接被拒绝,可能ssh没开,或端口号不对,亦或是防火墙限制
没有该连接地址
[root@localhost ~]# vim a.sh #!/usr/bin/expect //Expect二进制文件的路径 #超时时间 set timeout 20 //20秒等待时间 log_file test.log //日志文件 log_user 1 //日志用户 #参数传入 set hostname [lindex $argv 0] //追加参数0,统计变量并加载第1位置参数 set password [lindex $argv 1] //追加参数1,统计变量并加载第2位置参数 #追踪命令 spawn ssh root@$hostname //追踪命令 #捕捉信息并匹配免交互执行 expect { //捕捉提示信息 "Connection refused" exit //捕捉到拒接连接信息即退出 "service not konwn" exit //捕捉到服务为开启信息即退出 "(yes/no)" // 捕捉yes或no参数 {send "yes\r";exp_continue} //输入yes并继续执行 "*password" // 捕捉参数 {send "$password\r"} //输入密码参数 } #控制权交予控制台 interact //控制权转交控制台人为输入 exit //退出脚本 [root@localhost ~]# chmod +x a.sh //授予脚本执行权限 [root@localhost ~]# ./a.sh 192.168.235.134 123123 //运行脚本远程连接 spawn ssh root@192.168.235.134 root@192.168.235.134's password: Last login: Thu Oct 10 15:13:27 2019 from 192.168.235.1 //已成功远程登录 [root@localhost ~]# exit 登出 Connection to 192.168.235.134 closed. //退出远程登录
2.嵌入执行
案例演示:
创建用户jarry,密码123123
[root@localhost ~]# vim c.sh #!/bin/bash user=$1 password=$2 #非交互命令放expect外面 useradd $user #开始交互 expect <<-EOF //Expect开始标志,标准性输入,等同于stdin spawn passwd $user expect "新的*" send "$password\r" expect "重新*" send "$password\r" expect eof; EOF //Expect结束语句,EOF前后不能有空格 [root@localhost ~]# chmod +x c.sh [root@localhost ~]# ./c.sh jarry 123123 spawn passwd jarry 更改用户 jarry 的密码 。 新的 密码: 无效的密码: 密码少于 8 个字符 重新输入新的 密码: passwd:所有的身份验证令牌已经成功更新。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
交互shell从tty读取用户输入。shell默认会读取启动文件,显示提示符和打开任务控制等。用户可以和shell交互。 脚本总是运行在非交互的shell上。同样,脚本可以访问它自己的tty,这使得在脚本中依然可以模拟出交互的shell。 #!/bin/bash MY_PROMPT='$ ' while : do echo -n "$MY_PROMPT" r
问题内容: 我需要确定调用我的Python脚本的外壳是否处于交互模式。如果它处于交互模式,则程序应将输出通过管道传递到less(1)以便于阅读。如果没有,它应该只将其输出打印到stdout,以便将其通过管道传输到打印机,文件或其他寻呼机。 在shell脚本中,我将检查是否定义了提示变量$ PS1,或者在$-变量中存储的标志中寻找-i选项。 从Python内部测试交互性的首选方法是什么? 问题答案:
本文向大家介绍shell脚本通过expect实现自动单边无密登录功能,包括了shell脚本通过expect实现自动单边无密登录功能的使用技巧和注意事项,需要的朋友参考一下 最近项目需要实现单边无密登录,去网上搜索了下相关文章,实践之后发现几乎都不能用。于是结合expect的使用方法自行写了一个,通过验证可用。现在总结在这供需要的朋友参考。 代码如下: 以上所述是小编给大家介绍的shell脚本通过e
本文向大家介绍shell之正向解析脚本的实现方法,包括了shell之正向解析脚本的实现方法的使用技巧和注意事项,需要的朋友参考一下 正向解析脚本 最后只要输入hosts www.cwq.com就能解析出地址192.168.17.156 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍shell之分离解析脚本的实现方法,包括了shell之分离解析脚本的实现方法的使用技巧和注意事项,需要的朋友参考一下 分离解析脚本 在运行脚本之前,需要VM虚拟机,Centos7,两台主机一台win10 -1 作为广域网的主机, 一台win10 -2作为区域网的主机。 之前我的博客有教程 最后我们用WINDOW去试一试解析域名 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望
本文向大家介绍Shell脚本中非交互式修改密码的两种方法,包括了Shell脚本中非交互式修改密码的两种方法的使用技巧和注意事项,需要的朋友参考一下 今天在写一个shell脚本的时候发现需要设置用户的密码,而设置密码是交互式的,这样在脚本中显然是不太好的,因此上网查找资料,发现了以下两种常见的非交互式设置密码的方式: 1:使用chpasswd chpasswd其实是通过用户输入'用户名:密码'来更改