第一站 - 轻松上网从此开始!

上网第一站

当前位置: > SEO >

Linux Shell脚本执行超时怎么办?

时间:2017-08-31 10:49来源:我来投稿获取授权
以下内容来自网络或网友投稿,www.swdyz.com不承担连带责任,如有侵权问题请联系我删除。投稿如果是首发请注明‘第一站首发’。如果你对本站有什么好的要求或建议。那么都非常感谢你能-联系我|版权认领
在shell里会有一种不太常见的情况,就是脚本有时候会出现超时的现象。一般来说遇到这种问题,我们都会简单粗暴的采用下面这种脚本来当超时看门狗: 这个脚本搭配两个变量使用的话,监

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

  

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

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

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

  

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

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

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

  

Linux Shell脚本执行超时怎么办?

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

  

Linux Shell脚本执行超时怎么办?

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

  

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

  

Linux Shell脚本执行超时怎么办?

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

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

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

(责任编辑:admin)
织梦二维码生成器
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
发布者资料
第一站编辑 查看详细资料 发送留言 加为好友 用户等级:注册会员 注册时间:2012-05-22 19:05 最后登录:2014-08-08 03:08
栏目列表
推荐内容
分享按鈕