使用shell做日志信息提取

前两天使用python写的,当时说要使用shell写下,研究了awk不行,改了个思路使用grep也可以完成。

语法很简单,就是grep两次,一次存在,一次不存在,然后将行数据重定向到文件中。

实现的内容:数据库迁移时,日志中的报错信息,有一部分是可以接受的正常的报错,有一些报错是不可以接受的,需要提取出来。

#!/bin/bash
:<<EOF
comment:db2 transfer log analyse.
author:
EOF

#逐行读取日志,并检查是否有errorcode=?
#如果有,并且?!=47120,则将数据行数、及code输出到日志分析结果文件中
row=1
sqlstate='SQLSTATE='
sqlcode='SQLSTATE=42710'
cat ddl.log | while read line
do
    if  echo $line|grep $sqlstate
    then
        if echo $line|grep $sqlcode
        then
            echo $line
        else
            echo $row" : "$line >> ddl.analysis.result.txt
        fi
    fi
    row=`expr $row + 1`
done

 

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值