免费注册 查看新帖 |

Chinaunix

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

[系统管理] 用 expect 来监控一个程序问题 [复制链接]

论坛徽章:
0
发表于 2013-05-23 15:07 |显示全部楼层
有一个程序, 假设为 cmd,
cmd 正常的时候列出一些 output,
不正常•的时候会像当机那样,跳不到下一个命令符

我想写一个 expect script 去监控另一台机执行 cmd 是否正常,
不正常的话, 过了 timeout 60 秒会退出返回值 exit 1

#!/usr/bin/expect

set timeout 60
spawn ssh host cmd
expect {
   expect "output" {exit 0}
   timeout {exit 1}
}

可惜结果是,不论 cmd 是否正常,都会立即退出,不会等待 60 秒

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2013-05-23 16:49 |显示全部楼层
不应该是这样吗?
  1. expect {
  2.    "output" {exp_continue}
  3.    timeout {exit 1}
  4. }
复制代码

论坛徽章:
0
发表于 2013-05-23 17:24 |显示全部楼层
seesea2517 发表于 2013-05-23 16:49
不应该是这样吗?


我之前打错了,我试了这个效果也是一样

论坛徽章:
0
发表于 2013-05-23 17:26 |显示全部楼层
seesea2517 发表于 2013-05-23 16:49
不应该是这样吗?


我之前打错了,我试了这个效果也是一样

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2013-05-23 17:53 |显示全部楼层
那,要不改成一个死循环:
  1. while true {
  2.     expect {
  3.        "output" {continue}
  4.        timeout  {exit 1}
  5.     }
  6. }
复制代码

论坛徽章:
0
发表于 2013-05-23 17:56 |显示全部楼层
sleep 60                           

论坛徽章:
0
发表于 2013-06-02 19:11 |显示全部楼层
回复 1# csccyab


    检查一下输出,与匹配的output的关系。
2楼正解
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP