免费注册 查看新帖 |

Chinaunix

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

请教关于tail的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-27 22:16 |只看该作者 |倒序浏览
要写一个script中有一个无限循环,不停检查一个logfile的更新,如果发现有关于error的log,就做一些错误处理,否则就延时一下。
可程序卡在tail -f 这句就不动了,可能tail -f也是个无限循环吧。请问有什么办法能解决这个问题么?学生刚刚开始学写shell script,还请大家指点。
p.s. 随着时间的增长,logfile 会变的很大(上G),所以才考虑用tial -f 检测。logfile是由另外一个程序不停的更新的。

while true; do

Errors=$(tail -f logfile | grep --line-buffered -aE "^Error" | wc -l)

if[$Errors -gt 0]
then
  <做一些错误处理>
else
  sleep 5
fi

done

论坛徽章:
0
2 [报告]
发表于 2009-07-27 22:30 |只看该作者
估算一下 sleep 5 这段时间里log增长了多少行 (比如200),
tail -f logfile 换成tail -200 logfile。

论坛徽章:
0
3 [报告]
发表于 2009-07-27 22:34 |只看该作者
建议:
把Error的处理放到抛出Error的地方,被动的检测无论响应速度还是资源开销都不及主动处理。

论坛徽章:
0
4 [报告]
发表于 2009-07-27 22:37 |只看该作者
tail -f logfile | while read line
do
  if echo $line | grep -q "your pattern"
  then
     #process errors
  fi
done

[ 本帖最后由 lululau 于 2009-7-27 22:46 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2009-07-27 22:40 |只看该作者
原帖由 kwokcn 于 2009-7-27 22:34 发表
建议:
把Error的处理放到抛出Error的地方,被动的检测无论响应速度还是资源开销都不及主动处理。


唉,没办法。抛出Error的是其他是设备,它就通过uart向我发log
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP