Linux高效查日志命令介绍

说明:之前介绍Linux补充命令时,有介绍使用tail、grep命令查日志;

今天发现仅凭这两条命令不够,本文扩展介绍一下。

命令一:查看日志开头

powershell 复制代码
head -n 行数 日志路径

如下,可以查看程序启动是否正常;

命令二:查看日志末尾

powershell 复制代码
tail -n 行数 日志路径

能查看最新的日志信息,在日志行数非常多的情况下,这个命令很好用。不然,百万行的日志记录,用cat或者more,不可想象。

命令三:实时查看日志末尾

powershell 复制代码
tail -f -n 行数 日志路径

实时查看最新的部分日志记录,在程序打印日志量少的情况下,可以敲完命令,然后去触发BUG,能显示触发BUG的错误信息,很有用,也很局限,因为一般大项目,控制台会一直刷日志的。

命令四:查询关键词所在行

powershell 复制代码
grep -rina "关键词" 日志路径

查询关键词所在行的信息,这个日志用得不多,一般可以用来验证日志里是否打印了某行日志,用来判断程序执行情况。

比如,在代码里有以下代码;

java 复制代码
	log.info("进入xx方法");

就可以用这个作为关键词去搜一下,看有没有这行日志。平常,我用这个命令搜配置文件比较多,可以快速查看配置文件中某个配置项的设置。

注,引号里面的关键字就是模糊匹配的,不用在另外加百分号了,不要敲成下面这样。

powershell 复制代码
grep -rina "%url%" application-test.yml

命令五:查询关键词最后一次出现的位置

powershell 复制代码
grep -rina "关键词" 日志路径 | tail -n 行数

这个可以用来找最后一次出现异常的地方,可以找到当时出现的时间点,很有用。

命令六:查询关键词上下文内容

powershell 复制代码
grep -C 行数 "关键词" 日志路径

这个可以查看关键词附近的日志信息,能完整的看到异常附近的日志内容。其中-B指前几行,-A指后几行,而-C是上下各多少行。如下:

命令七:查询关键词最后一次出现的上下文内容

powershell 复制代码
grep -C 行数 "关键词" 日志路径 | tail -n 行数(结合前面,最好等于前面行数的2倍,因为前面是-C,上下各多少行)

这个命令值前面的组合,能找到最后一次出现异常时的上下文内容,快速定位到异常;

总结

本文介绍了查看日志的几个命令,可以高效查日志

相关推荐
不知几秋4 小时前
数字取证-内存取证(volatility)
java·linux·前端
珊珊而川5 小时前
ChatPromptTemplate创建方式比较
服务器·langchain
欧先生^_^7 小时前
Linux内核可配置的参数
linux·服务器·数据库
若风的雨7 小时前
【deekseek】P2P通信路由过程
服务器·网络协议·p2p
海尔辛7 小时前
学习黑客5 分钟读懂Linux Permissions 101
linux·学习·安全
Python私教7 小时前
征服Rust:从零到独立开发的实战进阶
服务器·开发语言·rust
王RuaRua8 小时前
[数据结构]5. 栈-Stack
linux·数据结构·数据库·链表
曼岛_8 小时前
[架构之美]linux常见故障问题解决方案(十九)
linux·运维·架构
tan180°8 小时前
Linux进程信号处理(26)
linux·c++·vscode·后端·信号处理
大神的风范9 小时前
从0开始学linux韦东山教程第三章问题小结(4)
linux·服务器