免费注册 查看新帖 |

Chinaunix

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

请教一个处理syslog的脚本 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-25 09:27 |只看该作者 |倒序浏览
从/var/log/syslog
里面过滤出10天内包含warning 或者 failed 或者 panic的行信息

因为syslog的格式问题,我的方法比较笨,先查当天date后计算出十天前的日子然后用awk去匹配,但是awk中使用shell变量出问题了
请教高手的简洁办法
  1. Mar 24 17:41:10 joe-desktop kernel: [  264.009019] type=1503 audit(1269423670.027:6): operation="inode_permission" requested_mask="x::" denied_mask="x::" fsuid=0 name="/usr/lib/vmware-tools/bin32/vmware-tpvmlp" pid=5817 profile="/usr/sbin/cupsd"


  2. Mar 24 17:41:10 joe-desktop kernel: [  264.009019] type=1503 audit(1269423670.027:6): operation="inode_permission" requested_mask="x::" denied_mask="x::" fsuid=0 name="/usr/lib/vmware-tools/bin32/vmware-tpvmlp" pid=5817 profile="/usr/sbin/cupsd"
复制代码
以上是syslog的格式

论坛徽章:
0
2 [报告]
发表于 2010-03-25 09:43 |只看该作者
回复 1# oppajoe

我的方法确实老土了点
而且一点也不简洁,完全不符合脚本的用意,请高手指点
  1. SYSLOG=/var/log/syslog
  2. TIMESTAMP=`date "+20%y%m%d"`
  3. FILLOG=/usr/local/job/log$TIMESTAMP.txt

  4. Month_List=(Dec Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec )
  5. Month=`date "+%m"`
  6. Month1=${Month_List[$Month]}
  7. Month2=${Month_List[$Month]}
  8. Day1=`date "+%d"`
  9. Day2=`expr $Day1 - 10`

  10. Getdate() {
  11.         if [ $Day1 -lt 10 ]; then
  12.                 Day2=`expr $Day2 + 30`               
  13.                 Month2=${Month_List[$Month-1]}
  14.         fi
  15. }

  16. Getdate
  17. grep warn* $SYSLOG | awk -v m1=$Month1 -v m2=$Month2 -v d1=$Day1 -v d2=$Day2 '{if(($1==m1&&$2>=d1)||($1==m2&&$2<=d2)) print $0}' > $FILLOG

复制代码

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
3 [报告]
发表于 2010-03-25 09:46 |只看该作者
装个GNU date 吧,省去很多麻烦。

$ date -d "-10 days" "+%b %d"
Mar 15
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP