使用expect自动化批量向多台机器分文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用expect自动化批量向多台机器分文件相关的知识,希望对你有一定的参考价值。

 自动化运维的过程中,某些时候我们需要受用输入密码,这时候Expect这个工具可以完成。


首先要安装expect,直接yum安装就可以的。

下来我们试试expect这个工具:

使用ssh登陆:

#!/bin/expect                                      #脚本解释器
spawn ssh [email protected]  uptime             #开启expect自动交互,执行ssh命令
expect "*password" {send "123456\n"}               #如果ssh命令输出匹配*password,就发送123456给系统
expect eof                                         #表示交互结束

下来时匹配多个expect:

#!/bin/expect

spawn ssh [email protected]  uptime

expect {                                       #将多个字符放在expect里面,然后spawn执行的过程中进行匹配
  "yes/no" {exp_send "yes\r";exp_continue}      #exp_send和前面的send一样,匹配多个字符串在每次匹配并执行动作后,加上exp_continue
  "*password" {exp_send "123456\n"}
}
expect eof

利用expect响应shell脚本中的多个read读入:

shell脚本:
#!/bin/bash
read -p "plz input your username:" name
read -p "plz input your password:" pass
echo -en "your username $name,your password $pass\n"
~
expect脚本:
#!/bin/expect
spawn sh /root/32.sh
expect {
  "username" {exp_send "xpg\r";exp_continue}
  "password" {exp_send "123456\n"}
}
expect eof
~

18.4.5 send_user命令

相当于echo -n这个命令:

#!/bin/expect
send_user "I AM OLDBOY\n"
send_user "I am who?\n"

18.4.6 exit命令

类似shell中的shell,直接退出expect脚本,除了基本的退出脚本功能之外,还可以利用这个脚本做一些关闭前的清理和提示等工作:

#!/bin/expect
send_user "I AM OLDBOY\n"
send_user "I am who?\n"
exit -onexit {
  send_user "Good bye\n"
}

18.5 Expect程序变量

18.5.1普通变量

定义变量的基本语法如下:

set   变量名   变量值

打印:

puts   $变量名

#!/bin/expect
set password "123456"
puts $password

18.5.2特殊参数变量

在expect里有与shell脚本里的$0,$1,$2等类似的特殊参数变量,用于接收及控制expect脚本传参。

在expect中$argv表示参数数组,可以使用[lindex  $argv n]接收expect脚本传参,n从0开始,分别表示第一个[lindex $argv0] 参数、

例如:

#!/bin/expect
set file [lindex $argv 0]
set user [lindex $argv 1]
set dir  [lindex $argv 2]

puts $argv0
puts $argc
puts $file
send_user "your name is $user;your dir is $dir\n"

18.6 Expect程序中的if条件语句

if { 表达式 } {

    指令

}

或者

if { 条件表达式 }  {

    指令

}else  {

指令

}

范例18-9 使用if语句判断脚本传参的个数,如果不符合给予提示:

#!/bin/expect
if { $argc != 3 } {
   send_user "usage:expect $argv0 file host dir/n"
   exit -onexit {
   send_user "Good bye bye"
   }
}
set file [lindex $argv 0]
set host [lindex $argv 1]
set dir  [lindex $argv 2]

puts $file
puts $argv0
puts $argc
~

18.7 timeout 关键字

这个关键字是服务于全局的,而不是某一个;和shell中的sleep很像,休息30s。

18.8企业生产场景下expect案例

  1. 开发expect自动交互的脚本:

#!/bin/expect
if { $argc != 2 } {
   send_user "usage:expect $argv0 ip cmd/n"
   exit
   }

set ip   [lindex $argv 0]
set cmd  [lindex $argv 1]
#set dir  [lindex $argv 2]
spawn ssh [email protected]$ip  $cmd
expect {
   "yes/no" {exp_send "yes\r";exp_continue}
   "*password" {exp_send "123456\n"}
}
expect eof

上面是一个,我们向想办法批量执行execpt脚本试试:

用这个脚本调用上面的脚本,就可以实现循环批量

#!/bin/bash
if [ $# - ne 1 ]
  then
    echo "USAGE:$0 cmd"
    exit
fi

cmd=$1

for i in 136 137
do
  expect /root/4.exp 192.168.116.$i $cmd
done

18.8自动化 批量发送文件 **

下面这两个脚本相结合就能实现

#cat 5.exp
#!/bin/expect

if { $argc != 3 } {
  send_user "plz input:usage $argv0 ip cmd"
  exit
}
set file [lindex $argv 0]
set ip   [lindex $argv 1]
set dir  [lindex $argv 2]

spawn scp -rp $file [email protected]$ip:$dir

expect {
  "yes/no" {exp_send "yes\r";exp_continue}
  "*password" {exp_send "123456\n"}
}
expect eof
#cat 55.sh
#!/bin/bash
if [ $# -ne 2 ]; then
   echo "plz input $0 file dir"
   exit
fi
file=$1
dir=$2
for i in 136 137
do
   expect 5.exp $file 192.168.116.$i $dir
done
~


以上是关于使用expect自动化批量向多台机器分文件的主要内容,如果未能解决你的问题,请参考以下文章

expect脚本同步文件,expect脚本指定host和要同步的文件,构建文件分发系统,批量远程执行

批量远程执行命令

脚本要求:两类机器一共300多台,写个脚本自动清理这两类机器里面的日志文件。

linux系统,多台机器ssh免密码登录同一台机器执行某个脚本,不需要expect

expect脚本同步文件expect脚本指定host和同步的文件构建文件分发系统批量远程执行命

expect脚本同步文件,expect脚本指定host和要同步的文件,构建文件分发系统,批量远程执行