免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3113 | 回复: 2

如何加快下面expect脚本的ssh logout速度 [复制链接]

论坛徽章:
0
发表于 2009-05-08 21:55 |显示全部楼层
以下是我的ssh 自动登录脚本

#!/usr/bin/expect -f
#auto ssh login
#./autopasswd.sh user ip/host passwd
set timeout 1

set sshuser [lindex $argv 0]
set sshhost [lindex $argv 1]
set sshpasswd [lindex $argv 2]

spawn ssh  -v -l $sshuser -p22 $sshhost
expect "root@$sshhost's password:"

send "$sshpasswd\r"

interact

注:ssh -v 中的-v是我添加用于观察ssh登录过程中哪个地方是速度瓶颈的,实际使用可以删除

但是上面脚本有个问题在于interact以后,到你^D退出的时候,发现其实ssh 已经退出了,但是
expect脚步退出还要等一段时间,你可以通过
ssh 登录后退出对比就知道,其实通过ssh -v模式就知道应该是expect从交互模式的fsck到expect这个时间,
想问一下,有什么方法可以加快这个退出expect的时间呢?主要是因为上面这个如果自动化脚本用也够用了,
但是我平时也用来交互式自动登录到某台机器后退出,所以不可忍受这个退出速度

[ 本帖最后由 hanksuper 于 2009-5-8 22:06 编辑 ]

论坛徽章:
20
CU大牛徽章
日期:2013-04-17 11:48:26羊年新春福章
日期:2015-03-10 22:39:202015年中国系统架构师大会
日期:2015-06-29 16:11:282015亚冠之平阳省
日期:2015-07-31 09:19:042015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-09-30 06:20:002015亚冠之柏太阳神
日期:2015-10-19 20:29:5915-16赛季CBA联赛之天津
日期:2016-11-29 14:03:4315-16赛季CBA联赛之北控
日期:2016-12-24 20:51:492015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-12 20:58:532014年中国系统架构师大会
日期:2014-10-14 15:59:00
发表于 2009-05-11 23:03 |显示全部楼层
貌似expect执行命令会比较慢

论坛徽章:
0
发表于 2012-06-28 17:25 |显示全部楼层
同有这个问题,它在执行退出后会有1秒左右的延迟,打开-d模式可以看到它输出如下字段:
write() failed to write anything - will sleep(1) and retry

有人知道如何把这1秒给去掉吗
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP