前两天使用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