linux 命令运行超时,Linux Shell脚本执行超时怎么办?

6b6968c9af07cf0cb12685e2e331906c.png

在shell里会有一种不太常见的情况,就是脚本有时候会出现超时的现象。一般来说遇到这种问题,我们都会简单粗暴的采用下面这种脚本来当“超时看门狗“:

b0bb28ead8dc6347f2b01f86133db454.png

这个脚本搭配两个变量使用的话,监控一点小代码还算OK,但是它的逻辑还是比较粗糙,比如如果在这个脚本执行的时候,又有了一个新的process在后台启动,那么kill掉的就是新的process,而本应该停止的脚本还是在后台肆无忌惮的跑着。

为了不滥杀无辜,所以遇到这种情况,就要使用timeout命令,具体的用法请自行#man timeout,这个命令在centos 6里就是自带的。

假设我们要ping www.baidu.com ,同时要求“若超过了5秒没有反应,就停止这个任务”。那么就是用命令:#timeout 5s ping www.baidu.com,效果如图:

fdfdfe19197b3be54ca40f10a22ffb1c.png

从26秒到31秒,的确达到了5秒就跳出的效果。

牛刀小试结束,那么现在我们就来进化一下我们之前的那个MQ脚本,之前在 http://chenx1242.blog.51cto.com/10430133/1884415 里我曾经写过一个MQ脚本,但是那个MQ脚本有点理想化了,里面忘记了添加“超时监控”以及“重启失败的话会发邮件提醒运维人员”这两个功能,在这里我们就把上面两个短板补齐。

首先,我们先运行一下看看这个MQ看门狗脚本需要运行的时间:

191ba9bb79fdec96fc83222f3e86d250.png

从上面可见整个脚本运行大约需要13秒,那么我们考虑到其他因素设定超时时间为20秒,执行效果如图:

04d09dbd6daba90f384c126ca184f4f6.png

返回码是0,那么再看看如果因为超时而停止的返回码是多少呢?

ee8d0e806f301799ec2a78408d5fcdfc.png

可见由于超时停止的返回码是124(ctrl+c手动退出的返回码是130),那么整个脚本就很好写了,如下:

4b198b265ba92ab922ae1b1fe6c8d53d.png

然后在crontab里直接执行这个脚本就好了。

补充说明之一,在文中测试timeout命令的时候,我使用了ping,其实这个是不严谨的,因为unix的ping默认会***重复,所以#timeout 3s ping www.baidu.com 不管有没有网络连接都会超时。这里***的例子是看看#timeout 3s sleep 1和#timeout 3s sleep 5的区别。

补充说明之二,在shell脚本里,timeout后面若跟函数的话是无效的!

【编辑推荐】

【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值