日志实时监控与分析:使用 tail 和 grep 提升开发者日志管理技能

查看日志是一个程序员必备的技能,尤其是项目部署在linux系统,当线上出现问题的时候除了日志平台能够直观的查看项目的运行情况以外,用的最多的可能就是在linux中查看日志了,虽然通过cat或tail都可以很直观的观察实时日志的打印,但日志多的情况下你是否也需要一行一行的看执行结果呢,这样显然是时分浪费时间的,今天就说一下节省时间的查看日志方式。

1. 实时查看日志

lua 复制代码
tail -f nohup.log

上述命令将持续输出日志文件的尾部内容,并在文件有新的日志条目时实时刷新。

控制台打印样例

2. 过滤查看日志

有时候,日志文件可能包含大量信息,但我们只对某些特定的关键字感兴趣。这时,grep 命令就派上用场了。例如,如果我们只关心包含 "206" 的日志:

bash 复制代码
tail -f test.log | grep "206"

控制台打印样例

如果想过滤多个字段呢,又该怎么写

tail -f test.log | grep "206|Kafk"

只需要在原来的基础上用|分开即可

控制台打印样例

缺点是什么

这样输出格式只会输出过滤字段所在的行,如果行中不包含过滤字段,则整行日志都不会输出,那假如说有错误日志输出的情况下还是看不了,这样做还是不太方便,那怎么做才是最合理的呢,继续向下看

3. 实时输出+高亮展示+全部内容

现在只需要对tail -f test.log | grep "206|Kafk"命令优化一下即可,优化后的命令:tail -f test.log | grep -E "206|Kafk|$"在末尾追加|$,日志便可以输出所有,意思是匹配到的日志就高亮,匹配不到的则正常输出

控制台打印样例

条件字段不但高亮了而且后续的内容也展示出来了,这样看日志的效率肯定会提高不少

4. 进阶

如果你还想整点花活,那一定少不了进阶版本,命令如下

tail -f test.log | grep -E ".*206.*|Kafk|$"以条件内容206为例,在原来的基础上用.*包裹条件内容,那么输出的格式就是匹配到的条件整行都高亮展示

控制台打印样例

相关推荐
左右用AI1 分钟前
每周1亿次下载的axios被投毒了,但是源码里没有一行恶意代码!
前端·后端
SimonKing1 分钟前
IDEA 2026.1重磅发布:AI智能体全面开放,编程进入“万能插座”时代
java·后端·程序员
星浩AI1 分钟前
刚刚,Claude Code 的源码泄露了
后端·github·ai编程
元俭2 分钟前
【Eino 框架入门】Callback 可观测性:给 Agent 装个"监控摄像头"
后端
我叫黑大帅4 分钟前
如何使用PHP创建图像验证码
后端·面试·php
何中应5 分钟前
Wiki搭建
后端·开源软件·wiki
AI茶水间管理员8 分钟前
手动执行 Claude 压缩上下文后,到底保留了什么?(附Vibe Coding 案例)
人工智能·后端
神奇小汤圆11 分钟前
AQS 同步器——Java 并发框架的核心底座全解析
后端
fy1216312 分钟前
Spring Boot项目中解决跨域问题(四种方式)
spring boot·后端·dubbo
gelald15 分钟前
Spring - IoC 容器原理
java·后端·spring