免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3448 | 回复: 6
打印 上一主题 下一主题

一个expect诡异的问题。 [复制链接]

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-08-09 16:57 |只看该作者 |倒序浏览
本帖最后由 expert1 于 2011-08-09 20:23 编辑

我ssh到一个机器,然后执行一个shell脚本,下边是expect的部分,ssh过去的部分我就不贴。

上边是登陆部分,登陆成功提示符“#”
expect "#"
send "du -sh tmp.exp |awk '{print \$1}'\r"
expect -re {.*\/(.*)\r\n.*}
expect "#"
send "exit\r"
expect eof
我发现了一个奇怪的现象,执行多次有时候会卡住到超时,看debug内容:
expect: does " du -sh tmp.exp |awk '{print $1}'\r\n8.0K\r\n[root@monitor ~]# " (spawn_id exp7) match regular expression ".*\r\n(.*)\r\n.*"? yes
expect: set expect_out(0,string) " du -sh tmp.exp |awk '{print $1}'\r\n8.0K\r\n[root@monitor ~]# "
expect: set expect_out(1,string) "8.0K"
expect: set expect_out(spawn_id) "exp7"
expect: set expect_out(buffer) " du -sh tmp.exp |awk '{print $1}'\r\n8.0K\r\n[root@monitor ~]# "


expect: does "" (spawn_id exp7) match glob pattern "#"? no
就这里开始卡住了。
原来失败的时候,expect -re expect -re {.*\/(.*)\r\n.*}
把下一个[root@localhost~]#都给匹配上了,导致了最后的expect "#"没东西可以匹配,所以超时,而奇怪的是,有时候又能执行,看结果是这个re没把[root@localhost~]# 匹配,所以下一个expect "#"执行OK了,exit退出。debug如下:
expect: does " du -sh tmp.exp |awk '{print $1}'\r\n8.0K\r\n" (spawn_id exp7) match regular expression ".*\r\n(.*)\r\n.*"? yes
expect: set expect_out(0,string) " du -sh tmp.exp |awk '{print $1}'\r\n8.0K\r\n"
expect: set expect_out(1,string) "8.0K"
expect: set expect_out(spawn_id) "exp7"
expect: set expect_out(buffer) " du -sh tmp.exp |awk '{print $1}'\r\n8.0K\r\n"
8.0K

expect: does "" (spawn_id exp7) match glob pattern "#"? no

expect: does "[root@localhost ~]# " (spawn_id exp7) match glob pattern "#"? yes

我就纳闷了,同一个机器,执行多次,居然这样的结果,如何来控制这种异常?
感觉失败的时候buffer区域滚动的东西太多了,但同一个re为啥有时候能匹配,有时候又不能?

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
2 [报告]
发表于 2011-08-09 17:26 |只看该作者
表达式是贪婪的,expect是节省的,所以构造模式很重要,exploring expcet里好象有讲解

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
3 [报告]
发表于 2011-08-09 17:40 |只看该作者
回复 2# waker


    那怎么会出现有时候懒惰匹配,有时候贪婪的情况呢,同一个re,同一个机器,呵呵。

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
4 [报告]
发表于 2011-08-09 18:42 |只看该作者
http://books.google.com.hk/books ... e&q&f=false

89页
好象还有其它地方讲解,没仔细翻

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
5 [报告]
发表于 2011-08-09 20:23 |只看该作者
回复 4# waker


    多谢waker老大

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
6 [报告]
发表于 2011-08-09 21:50 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
7 [报告]
发表于 2011-08-10 07:56 |只看该作者
草帽叔啥都知道.
zooyo 发表于 2011-08-09 21:50

碰巧翻过这本书而已
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP