Expect学习摘要

Expect常用语法简介:

1、#!/usr/bin/expect

这一行告诉操作系统脚本里的代码使用那一个shell来执行。这里代表expect的程序路径。 (#注意:这一行需要在脚本的第一行。) 如果你在第一行(#!那行)使用-d (debug参数),可以在运行的时候输出一些很有用的信息。 使用“-c”选项,从命令行执行expect脚本; 使用“-i”选项交互地执行expect脚本; 使用“-f”选项被指定为-file。

2、set timeout 30

设置超时时间为多少秒,计时单位是:秒。timeout -1 为永不超时。

3、spawn ssh -l username 192.168.1.1

spawn是进入expect环境后才可以执行的expect内部命令,如果没有装expect或者直接在默认的SHELL下执行是找不到spawn命令的。所以不要用 “which spawn“之类的命令去找spawn命令。好比windows里的dir就是一个内部命令,这个命令由shell自带,你无法找到一个dir.com 或 dir.exe 的可执行文件; 它主要的功能是给ssh运行进程加个壳,用来传递交互指令。

4、expect "password:"

这里的expect也是expect的一个内部命令,有点晕吧,expect的shell命令和内部命令是一样的,但不是一个功能,习惯就好了。这个命令的意思是判断上次输出结果里是否包含“password:”的字符串,如果有则立即返回,否则就等待一段时间后返回,这里等待时长就是前面设置的30秒 。

5、send "ispass\r"

这里就是执行交互动作,与手工输入密码的动作等效。 温馨提示: 命令字符串结尾别忘记加上“\r”,如果出现异常等待的状态可以核查一下。

6、interact

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

7、$argv 参数数组

expect脚本可以接受从bash传递过来的参数.可以使用[lindex $argv n]获得,n从0开始,分别表示第一个,第二个,第三个....参数。 ####例如下面的expect例子:

./launch.exp 1 2 3

launch.exp脚本就会接受后面三个参数,而在脚本中将可以用这个函数截取这些参数使用。

8、$argc 统计接受参数个数

./launch.exp 1 2 3 (这个脚本执行接受的参数为3个) 参数运用方面还有很多技巧:

比如$argc 存储了参数个数,args被结构化成一个列表存在argv。$argv0 被初始化为脚本名字。

expect的命令行参数参考了c语言的,与bash shell有点不一样。其中,$argc为命令行参数的个数,$argv0为脚本名字本身,$argv为命令行参数。[lrange $argv 0 0]表示第1个参数,[lrange $argv 0 4]为第一个到第五个参数。与c语言不一样的地方在于,$argv不包含脚本名字本身。

9、send_user #回显用户发出的信息,类似于shell中的echo而已。
exp_continue的用法:
#!/usr/bin/expect -f
set ipaddr "localhost"
set passwd "iforgot"
spawn ssh root@$ipaddr              #spawn   意思是执行命令,expect内命令,shell中不存在
expect {
"yes/no" { send "yes\r"; exp_continue}
"password:" { send "$passwd\r" }
}
expect "]# "
send "touch a.txt\r"                       #意思为发送命令
send "exit\r"
expect eof
exit

exp_continue可以继续执行下面的匹配,简单了许多。还有一点,让我认识到匹配不见得要匹配最后几个字符,匹配可以是一行中任意的。 ####综合性的例子:

./sshlogin.exp password 192.168.1.11 who
cat sshlogin.exp
#!/usr/bin/expect -f
# Expect script to supply root/admin password for remote ssh server
# and execute command.
# This script needs three argument to(s) connect to remote server:
# password = Password of remote UNIX server, for root user.
# ipaddr = IP Addreess of remote UNIX server, no hostname
# scriptname = Path to remote script which will execute on remote server
# If you username and passwd has not pass the rsa trust, your login will fail.
# Usage For example:
#  ./sshlogin.exp password(参数一) 192.168.1.11 who
# ------------------------------------------------------------------------
# Copyright (c) 2004 nixCraft project <http://cyberciti.biz/fb/>
# This script is licensed under GNU GPL version 2.0 or above
# -------------------------------------------------------------------------
# This script is part of nixCraft shell script collection (NSSC)
# Visit http://bash.cyberciti.biz/ for more information.
# ----------------------------------------------------------------------
# set Variables
set password [lrange $argv 0 0]                   #设置password为接受的第一个参数
set ipaddr [lrange $argv 1 1]                     #设置ipaddr为接受的第二个参数
set scriptname [lrange $argv 2 2]                 #设置scriptname为接受的第三个参数
set arg1 [lrange $argv 3 3]                       #设置arg1为接受的第四个参数
set timeout -1                                    #设置为永不超时。
# now connect to remote UNIX box (ipaddr) with given script to execute
spawn ssh yourusername@$ipaddr $scriptname $arg1
match_max 100000                                  #设置缓冲区大小,单位:字节
# Look for passwod prompt
expect "*?assword:*"
# Send password aka $password
send -- "$password\r"
# send blank line (\r) to make sure we get back to gui
send -- "\r"
expect eof

####用expect实现ssh自动登录对服务器进行批量管理:

1.实现ssh自动登录完成任务的expect脚本
#!/usr/bin/expect -f
set ipaddress [lindex $argv 0]
set passwd [lindex $argv 1]
set timeout 30
spawn ssh shellqun@$ipaddress
expect {
"yes/no" { send "yes\r";exp_continue }
"password:" { send "$passwd\r" }
}
expect "*from*"
send "mkdir -p ./tmp/testfile\r"
#send "exit\r"
expect "#"  命令运行完, 你要期待一个结果, 结果就是返回shell提示符了(是# 或者$)
#最后一句第13行的解释:
  
其实写成 interact 的最大好处是登录后不会退出,而会一直保持会话连接,可以后续手动处理其它任务,请根据实际情况自行选择了。
2.调用login.exp完成批量管理
#!/bin/bash
for i in `awk '{print $1}' passwd.txt`
do
j=`awk -v I="$i" '{if(I==$1)print $2}' passwd.txt`
expect /root/shell/login.exp $i $j
done
3.passwd.txt
192.168.0.2  password2
192.168.0.3  password3

####原文链接: http://www.cnblogs.com/iloveyoucc/archive/2012/05/11/2496433.html http://blog.csdn.net/zhuying_linux/article/details/6904568

转载于:https://my.oschina.net/nortorm/blog/424010

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值