小型自动化运维--expect脚本V2版

本文介绍如何使用expect脚本V2版实现远程主机登录及数据操作后自动退出。通过具体脚本示例,展示如何进行远程命令执行,并提供了一些实用技巧。

小型自动化运维--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


执行结果,截图如下:

wKioL1j27VHzspPWAABNBWkHH7Q751.png







     本文转自品鉴初心51CTO博客,原文链接:http://blog.51cto.com/wutengfei/1917339,如需转载请自行联系原作者


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值