小型自动化运维--expect脚本V2版
在实际运维工作中,需要我们向远程主机同步数据,可以用rsync来实现。那么用expect脚本怎么实现数据传输完成之后自动退出远程主机呢?在开始expect脚本V2版之前,我们先来看下,使用expect脚本来实现远程主机的登入,脚本如下:
#! /usr/bin/expect
set host "192.168.8.120"
set passwd "wtf"
spawn ssh root@$host
expect {
"yes/no" { send "yes\r"; exp_continue}
"password:" { send "$passwd\r" }
}
interact
注:上面脚本不明白的童鞋,请查看下我的51cto博客:小型自动化运维--expect脚本!
对上面脚本进行扩充,即是我们现在要说的expect脚本V2版:
#!/usr/bin/expect
set timeout -1 ##表示永不超时,timeout 0表示立即超时
set host "192.168.8.120"
set passwd "wtf"
spawn ssh root@$host
expect {
"yes/no" { send "yes\r"; exp_continue}
"password:" { send "$passwd\r" }
}
expect "]*"
send "touch /tmp/12.txt\r"
expect "]*"
send "echo 1212 > /tmp/12.txt\r"
expect "]*"
send "exit\r"
expect eof
对带颜色部分脚本进行说明:
语法结构很简单,自动登录的 expect 脚本,增加固定语法
expect "]*"
send "command"
expect "]*"
send "command"
..........
expect "]*"
send "exit\r"
注:
(1)expect "]*" 这里的 * 表示通配符,可以是 $,也可以是 #,root 用户的命令行提示符为 [root@localhost sbin]# , 是以 “]*” 结尾的,当 expect 脚本遇到 “]*” 则发送命令。
建议:这里的符号最好是到机器上面确认一下,如果是 # ,为了标准化,也可以把统配符 *
改为 标准匹配 #。
(2)可以再 #! /usr/bin/expect 下面增加一行 set timeout 30,表示如果 30 秒还没有连接成功,则取消尝试。 set timeout -1 , 则表示永不超时。如果不设置 timeout ,有可能在传输较大的文件的时候中断。
最后,对文件授予执行权限:
[root@cacti sbin]# chmod +x 2.expect
执行结果,截图如下: