Linux日志查看技巧

1.less + grep/zgrep

常见的日志查看有more,vim,cat,less,其中less是部分加载,适合大日志文件查看

 less -N +102g test.log  --N是显示行号的参数。

参数

"less -e" 当文件显示结束后,自动离开,无需输入"q"
"less -f" 强迫打开特殊文件,例如外围设备代号、目录和二进制文件
"less -m" 显示类似more命令的百分比
"less -N" 显示每行的行号
"less -s" 将连续的空行合并成一行显示
"less -S" 行信息过长时,将超出部分舍弃

快捷键

f : 查看下一页(f为forward的意思)
b : 查看上一页(b为back的意思)

PageDown : 查看下一页
PageUp   : 查看上一页

d : 查看下半页
u : 查看上半页

空格键 : 向下滚动一页
回车键 : 向下滚动一行

h : 显示帮助界面
q : 退出less命令 

F: 实时查看文件

G:跳转到最后

g:跳转到第一行

grep使用的技巧非常多

1.基本用法

(1)从一个文件中搜索一个单词, (数据可以从文件,或stdin获取)grep match_pattern filename 或者 grep "match_pattern" filename

echo "this is a word\n next line" | grep word

(2)同时从多个文件中搜索grep "match_pattern" filename1 filename2 filename3 ......

(3)将搜索的关键字高亮, 结果行中match_pattern将高亮显示grep "match_pattern" filename --color

(4)只显示匹配的关键字,结果中每一行结果中只显示了match_patterngrep "match_pattern" filename -o

(5)显示不包含match_pattern的其它行grep "match_pattern" filename -v

(6)显示匹配上match_pattern的行数, 一行中多个match_pattern将计为1行grep "match_pattern" filename -c

(7)统计匹配上match_pattern的数量grep "match_pattern" filename -o | wc -l

(8)显示匹配上match_pattern的行号grep "match_pattern" filename -n

grep "match_pattern" filename1 filename2 -n #显示为 filename:lineNum: 匹配行

(9)显示样式匹配所位于的字符或字节偏移grep "match_pattern" filename -b -o

选项-b 总是和 -o 配合使用

match_pattern在匹配行的偏移值,起始值是0

(10)搜索多个文件并找出匹配文本位于哪一个文件中(显示所有包含match_pattern的文件名)grep "match_pattern" filename1 filename2 filename3 ... -l

(11)搜索多个文件并找出不包含match_pattern的文件列表grep "match_pattern" filename1 filename2 filename3 ... -L

2.高级应用


(1)递归搜索文件grep "match_pattern" dir -R

(2)搜索中包括或排查文件

在dir目录下的搜索.c和.cpp文件,进行match_pattern匹配(使用*.{c}时,结果为空,不知道为什么)grep "match_pattern" dir -r --include *.{c,cpp}

在dir目录下搜索除了filename文件grep "match_pattern" dir -r --exclude "filename"

如果需要排除的文件很多,可以将要排除的文件名写入一个文件FILE中,其中每一个文件名占一行grep "match_pattern" dir -r --exclude-from FILE

在dir目录下搜索除了subdir目录下的文件grep "match_pattern" dir -r --exclude-dir subdir

注意: subdir 不要写成subdir/ ,否则将不能排除

(3)输出'\0'值结束的文件名,并删除, -Z和-l结合使用grep "match_pattern" filename -l -Z | args -0 rm

(4)静默模式

不输出结果,只运行,根据运行返回结果,0 文件包含匹配项, 非0 文件不包含匹配项grep "match_pattern" filename -q

使用 #? 获得运行结果

(5)忽略样式match_pattern的大小写grep "match_pattern" filename -i

(6)匹配多个样式grep -e "match_pattern1" -e "match_pattern2" -e "match_pattern3"  filename

如果匹配模式很多,可以将匹配模式写入文件pattern_file中grep -f pattern_file  sourcefile

(7)打印出匹配文本之前或之后的行, 有多个匹配是以--作为各匹配的定界符

[1]打印匹配某个结果之后的4行(4中不包含匹配行)grep "match_pattern" filename -A 4

[2]打印匹配某个结果之前的5行grep  "match_pattern" filename -B 5

[3]打印出匹配文本之前和之后的3行grep "match_pattern" filename -C 3

3.参数详情

-i                                忽略大小写

-o                                只输出匹配项

-c                                只输出匹配行数

-b 与 -o联用,                    匹配模式在匹配行上的偏移值

-l                                只输出匹配上的文件名

-Z 与 -l 联用,                   将匹配上的文件名以'\0'结束输出

-L                                只输出不匹配的文件名

-v                                只输出不匹配的行

-n                                显示行号

-f pattern_file                   从文件中获得匹配模式

-q                                静默模式

-R / -r                           递归搜索

-A num                            显示匹配行的后num行

-B num                            显示匹配行的前num行

-C num                            显示匹配行的前和后num行

--color                           将匹配项高量显示

--include file_list               搜索包含的文件列表

--exclude file_list               排查的文件列表

--exclude-dir dir_list            排查的文件夹列表

--exclude-from file               从文件中获得需要排查的文件列表

less -N a.log | grep -in "exception|error"
less -N +320g a.log 

2.实时监控tail

tail -f -n 100 a.log      实时监控最后100行日志

tail -f  a.log | egrep -i "ERROR|exception"

tail -f  a.log | grep -i "ERROR|exception"

3.head查看文件前n行

head -100 a.log    显示前面100行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值