$ grep -ip 'DEACTIVATED' db2diag.log
$ grep -ip 'DEACTIVATED' db2diag.log
2017-09-17-12.03.33.048373+480 E1594733A513 LEVEL: Event
PID : 19726438 TID : 3343 PROC : db2sysc 0
INSTANCE: e105q5a NODE : 000 DB : SAMPLE
APPHDL : 0-81 APPID: *LOCAL.e105q5a.170917035458
AUTHID : E105Q5A HOSTNAME: db2b
EDUID : 3343 EDUNAME: db2agent (idle) 0
FUNCTION: DB2 UDB, base sys utilities, sqeLocalDatabase::FreeResourcesOnDBShutdown, probe:15127
STOP : DATABASE: SAMPLE : DEACTIVATED: NO
2017-09-17-12.03.58.149245+480 E1601224A513 LEVEL: Event
PID : 19726438 TID : 3343 PROC : db2sysc 0
INSTANCE: e105q5a NODE : 000 DB : SAMPLE
APPHDL : 0-109 APPID: *LOCAL.e105q5a.170917040333
AUTHID : E105Q5A HOSTNAME: db2b
EDUID : 3343 EDUNAME: db2agent (idle) 0
FUNCTION: DB2 UDB, base sys utilities, sqeLocalDatabase::FreeResourcesOnDBShutdown, probe:15127
STOP : DATABASE: SAMPLE : DEACTIVATED: NO
2017-09-17-12.16.49.507211+480 E1609705A513 LEVEL: Event
PID : 19726438 TID : 3343 PROC : db2sysc 0
INSTANCE: e105q5a NODE : 000 DB : SAMPLE
APPHDL : 0-125 APPID: *LOCAL.e105q5a.170917040401
AUTHID : E105Q5A HOSTNAME: db2b
EDUID : 3343 EDUNAME: db2agent (idle) 0
FUNCTION: DB2 UDB, base sys utilities, sqeLocalDatabase::FreeResourcesOnDBShutdown, probe:15127
STOP : DATABASE: SAMPLE : DEACTIVATED: NO
12. Multi-line records
Since mawk interprets RS as a regular expression, multi-line records are easy. Setting RS = "\n\n+",
makes one or more blank lines separate records. If FS = " " (the default), then single newlines, by
the rules for above, become space and single newlines are field separators.
For example, if a file is "a b\nc\n\n", RS = "\n\n+" and FS = " ", then there is one record
"a b\nc" with three fields "a", "b" and "c". Changing FS = "\n", gives two fields "a b" and
"c"; changing FS = "", gives one field identical to the record.
If you want lines with spaces or tabs to be considered blank, set RS = "\n([ \t]*\n)+". For compati-
bility with other awks, setting RS = "" has the same effect as if blank lines are stripped from the
front and back of files and then records are determined as if RS = "\n\n+". Posix requires that "\n"
always separates records when RS = "" regardless of the value of FS. mawk does not support this con-
vention, because defining "\n" as makes it unnecessary.
Most of the time when you change RS for multi-line records, you will also want to change ORS to
"\n\n" so the record spacing is preserved on output.
所以,在linux下面,命令如下:
$ awk 'BEGIN {RS = "\n\n+";ORS = "\n\n"} /DEACTIVATED/ {print $0}' db2diag.log
如果要反选,即不包含关键字的段落,在关键字前加上!
$ awk 'BEGIN {RS = "\n\n+";ORS = "\n\n"} !/DEACTIVATED/ {print $0}' db2diag.log
另外,也可以直接将RS设置为空串,效果是一样的
$ awk 'BEGIN {RS = "";ORS = "\n\n"} /DEACTIVATED/ {print $0}' db2diag.log
也可以按照其他方式分段,只需要指定正确的RS值即可。