日志实时监控与分析:使用 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为例,在原来的基础上用.*包裹条件内容,那么输出的格式就是匹配到的条件整行都高亮展示

控制台打印样例

相关推荐
程序员侠客行5 分钟前
Mybatis的Executor和缓存体系
java·后端·架构·mybatis
爱学习的小可爱卢16 分钟前
JavaEE进阶——Spring Bean与Java Bean的核心区别
java·后端·java-ee
37手游后端团队18 分钟前
Cursor 工作区使用技巧:让 AI 真正理解你的多项目协作
后端·面试·架构
武子康20 分钟前
大数据-198 KNN 必须先归一化:Min-Max 正确姿势、数据泄露陷阱与 sklearn 落地
大数据·后端·机器学习
李拾叁的摸鱼日常31 分钟前
Java Optional 最佳实践+注意事项+避坑指南
java·后端·面试
啊哈灵机一动39 分钟前
手把手实现 Gin + Socket.IO 实时聊天功能
后端
qq_124987075339 分钟前
基于微信小程序的科技助农系统的设计与实现(源码+论文+部署+安装)
java·大数据·spring boot·后端·科技·微信小程序·毕业设计
狂奔小菜鸡40 分钟前
Day35 | Java多线程入门
java·后端·java ee
哈哈老师啊1 小时前
Springboot新冠检测信息管理系统10m6v(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
华仔啊1 小时前
ArrayList 和 LinkedList 的区别?一篇讲透,从此开发和面试都不再纠结
java·后端