DDR爱好者之家 Design By 杰米

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:所有的身份验证令牌已经成功更新。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。