[特殊字符] Linux 日志查看与分析常用命令全攻略
在日常运维与开发排查中,我们经常需要查看服务日志来定位问题。本文系统整理了几种常用的日志查看命令,包括 tail
、cat
、grep
、split
、sed
等,并结合实际应用场景,提供了完整的使用方式和示例。
📌 一、tail
命令 —— 实时查看日志首选工具
1. 实时查看日志内容(默认显示最后 10 行)
tail -f main.log
用于监控日志新增内容,常用于排查线上服务运行时行为。
2. 查看日志最后 N 行(非实时)
tail -n 20 main.log
3. 逆序显示最后 N 行(稀有使用)
tail -r -n 10 main.log
4. 从第 N 行开始读取,再显示 M 行
cat main.log | tail -n +1000 | head -n 500
5. 查看日志中第 X 到 Y 行内容(如 1350 到 1400 行)
cat main.log | head -n 1400 | tail -n +1350
📌 二、cat
命令 —— 快速查看日志全文
1. 分页查看所有日志内容
cat main.log | more
2. 分页查看前 1000 行日志
tail -n 1000 main.log | more
📌 三、grep
命令 —— 精确查找日志内容利器
1. 打印匹配行及其上下文(前后 5 行)
grep -C 5 'pattern' main.log
等价于:
grep -5 'pattern' main.log
2. 打印匹配行及其前 5 行
grep -B 5 'pattern' main.log
3. 打印匹配行及其后 5 行
grep -A 5 'pattern' main.log
4. 高亮并显示匹配内容上下 10 行:
cat main.log | grep -n -B10 -A10 "关键词"
📌 四、split
命令 —— 日志太大?先分割再分析!
1. 按行数分割(每 50000 行为一个新文件)
split -l 50000 main.log newfile_ --verbose
2. 按字节大小切割(每个文件 40MB)
split -b 40m main.log -d newfile_ --verbose
📌 五、sed
命令 —— 批量处理日志内容的利器
1. 删除包含某关键词的日志行
sed -i '/关键词/d' main.log
📌 六、日志片段查找实战案例
1. 查询接口请求日志
grep 'Handling body of request[/api/vip-point]:{\"point\":{\"id\":411,\"hqId\":2500' main.log
2. 接口日志二次过滤,查看字段值(如 discount)
grep 'VipCardLevelController - Sending data to response:' main.log | grep discount
3. 将某段匹配日志导出到新文件
grep 'Handling body of request[/api/vip-point]:{\"point\":{\"id\":411,\"hqId\":2500' main.log > a.log
4. 关键接口查询 + 精确字段追踪(适用于大日志文件)
grep 'Handling body of request[/api/branch-feature]:{\"hqId\":2498,\"branchId\":8579,' main.log | grep fixedBusinessTime
✅ 实战技巧总结
场景 | 命令 |
---|---|
实时查看 | tail -f main.log |
查看最近 100 行 | tail -n 100 main.log |
查询关键词上下 10 行 | grep -C 10 'error' main.log |
查看日志第 1000 到 1500 行 | `cat main.log |
查询并导出日志 | grep '接口名' main.log > result.log |
删除日志中包含某关键词的行 | sed -i '/关键词/d' main.log |
切割大日志文件 | split -b 40m main.log newfile_ |
🎯 结语
掌握这些日志命令,可以大大提升我们在排查生产问题、分析系统行为时的效率。建议大家动手在测试环境中多实践,形成肌肉记忆。
如果你觉得有用,欢迎 收藏 + 点赞 + 关注我,我会持续更新更多实用 Linux 运维技巧和 Java 开发经验!
相关文章:
[特殊字符] Linux 日志查看与分析常用命令全攻略
在日常运维与开发排查中,我们经常需要查看服务日志来定位问题。本文系统整理了几种常用的日志查看命令,包括 tail、cat、grep、split、sed 等,并结合实际应用场景,提供了完整的使用方式和示例。 📌 一、tail 命令 ——…...

mysql-tpcc-mysql压测工具使用
在Linux系统上安装和配置tpcc-mysql进行MySQL的TPC-C基准测试,通常涉及以下几个步骤。请注意,由于tpcc-mysql不是一个官方工具,它可能需要从第三方仓库获取,如Percona提供的版本。 前置条件 确保MySQL或MariaDB已安装࿱…...

Qt找不到windows API报错:error: LNK2019: 无法解析的外部符号 __imp_OpenClipboard
笔者在开发中出现的bug完整报错如下: spcm_ostools_win.obj:-1: error: LNK2019: 无法解析的外部符号 __imp_OpenClipboard,函数 "void __cdecl spcmdrv::vCopyToClipboard(char const *,unsigned __int64)" (?vCopyToClipboardspcmdrvYAXPE…...
机试 | vector/array Minimum Glutton C++
题目地址 : C - Minimum Glutton #include<stdio.h> #include<iostream> #include<vector> #include<algorithm> using namespace std; int main() {//N:菜肴数,X:总甜度阈值,Y:总咸度阈值int…...

OpenCv高阶(十七)——dlib库安装、dlib人脸检测
文章目录 前言一、dlib库简介二、dlib库安装1、本地安装(离线)2、线上安装 三、dlib人脸检测原理1、HOG 特征提取2、 SVM 分类器训练3、 滑动窗口搜索4、非极大值抑制(NMS) 四、dlib人脸检测代码1、导入OpenCV计算机视觉库和dlib机…...

前端内容黑白处理、轮播图、奇妙的头像特效
1、内容黑白处理 (1)filter:滤镜 可以把包裹的区域中每一个像素点,经过固定的算法转换成另一种颜色来呈现 (2)grayscale:灰阶滤镜 取值范围:0~1取0:原图去1ÿ…...
蓝桥杯 10. 安全序列
当然可以,以下是整理后的 Markdown 格式题目描述: 题目描述 小蓝是工厂里的安全工程师,他负责安放工厂里的危险品。 工厂是一条直线,直线上有 n 个空位,小蓝需要将若干个油桶放置在这 n 个空位上。每 2 个油桶中间至…...
(10)-java+ selenium->元素之By class name
1.简介 继续介绍WebDriver关于元素定位大法,这篇介绍By ClassName。看到ID,NAME这些方法的讲解,应该知道,要做好Web自动化测试,最好是需要了解一些前端的基本知识。有了前端知识,做元素定位会很轻松,同样写网络爬虫也很有帮助 2.常用定位方法(8种) (1)id (2)nam…...

Git - .gitignore 文件
一、.gitignore 文件介绍 在使用 Git 进行版本控制时,.gitignore 文件是一个非常重要的配置文件,用于告诉 Git 哪些文件或目录不需要被追踪和提交到版本库中。合理使用 .gitignore 文件可以避免提交不必要的文件,如临时文件、编译生成的文件…...
MPI与多线程(如OpenMP)混合编程注意事项与性能优化
文章目录 MPI与多线程(如OpenMP)混合编程注意事项与性能优化混合编程注意事项性能优化策略示例代码编译与运行性能调优建议 MPI与多线程(如OpenMP)混合编程注意事项与性能优化 混合编程注意事项 MPI初始化与线程支持级别: 需要在MPI_Init之前调用MPI_Init_thread指…...
计算机网络学习(八)——MAC
一、MAC 在计算机网络中,MAC(Media Access Control,媒体访问控制)地址是数据链路层的重要概念,它用于唯一标识网络中的设备,并且在局域网(如以太网)中发挥关键作用。 MAC 是硬件地址…...
英语六级-阅读篇
目录 2023年12月大学英语真题(二) 十五选十(Section A) 单词表 短语表 译文 Passage Two(Section C) 单词表 短语表 译文 简介:其实我总结这篇文章就是平时记忆该阅读文章单词中出现的…...
右键打开 pycharm 右键 pycharm
文件夹右键打开pycharm aaa.reg notepad 右下角把文件格式改为:ansi Windows Registry Editor Version 5.00[HKEY_CLASSES_ROOT\Directory\Background\shell\PyCharm] "Open with PyCharm" "Icon""\"D:\\soft\\PyCharm 2024.1.4\\bi…...
机器人坐标系标定
机器人坐标系标定 机器人坐标系标定 1. 知识目标 理解机器人坐标系的定义掌握机器人坐标系的分类 2. 技能目标 能够正确标定机器人坐标系 3. 机器人坐标系的作用 代表不同的物体或边界示例: 相对于桌子、弓箭、坯料、其他机器或边界移动 用途: 使用…...
Flink流处理基础概论
文章目录 引言Flink基本概述传统数据架构的不足Dataflow中的几大基本概念Dataflow流式处理宏观流程数据并行和任务并行的区别Flink中几种数据传播策略Flink中事件的延迟和吞吐事件延迟事件的吞吐如何更好的理解事件的延迟和吞吐flink数据流的几种操作输入输出转换操作滚动聚合窗…...
【RabbitMQ】记录 InvalidDefinitionException: Java 8 date/time type
目录 1. 添加必要依赖 2. 配置全局序列化方案(推荐) 3. 配置RabbitMQ消息转换器 关键点说明 1. 添加必要依赖 首先确保项目中包含JSR-310支持模块: <dependency><groupId>com.fasterxml.jackson.datatype</groupId>&l…...

如何通过API接口实现自动化上货跨平台铺货?商品采集|商品上传实现详细步骤
一、引言:跨平台铺货的技术挑战与 API 价值 在电商多平台运营时代,商家需要将商品同步上架至淘宝、京东、拼多多、亚马逊、Shopee 等多个平台,传统手动铺货模式存在效率低下(单平台单商品上架需 30-60 分钟)、数据一致…...
《三维点如何映射到图像像素?——相机投影模型详解》
引言 以三维投影介绍大多比较分散,不少小伙伴再面对诸多的坐标系转换中容易弄混,特别是再写代码的时候可能搞错,所有这篇文章帮大家完整的梳理3D视觉中的投影变换的全流程,一文弄清楚这个过程,帮助大家搞清坐标系转换…...
Go 语言范围循环变量重用问题与 VSCode 调试解决方法
文章目录 问题描述问题原因1. Go 1.21 及更早版本的范围循环行为2. Go 1.22 的改进3. VSCode 调试中的问题4. 命令行 dlv debug 的正确输出 三种解决方法1. 启用 Go 模块2. 优化 VSCode 调试配置3. 修改代码以确保兼容性4. 清理缓存5. 验证环境 验证结果结论 在 Go 编程中&…...
青少年编程与数学 02-020 C#程序设计基础 04课题、常量和变量
青少年编程与数学 02-020 C#程序设计基础 04课题、常量和变量 一、主函数1. 主函数的基本格式2. 主函数的参数3. 主函数的返回值4. 主函数的作用5. 主函数的示例6. 主函数的注意事项 二、变量1. 变量的声明示例 2. 变量的初始化声明时初始化声明后赋值 3. 变量的类型3.1 值类型…...

零基础设计模式——结构型模式 - 适配器模式
第三部分:结构型模式 - 适配器模式 (Adapter Pattern) 欢迎来到结构型模式的第一站!结构型模式关注的是如何将类或对象组合成更大的结构,同时保持结构的灵活性和效率。适配器模式是其中非常实用的一个,它能帮助我们解决接口不兼容…...
【QT】TXT文件的基础操作
目录 一、QT删除TXT文件内容 方法1:使用QFile打开文件并截断 方法2:使用QSaveFile(更安全的写入方式) 方法3:使用QTextStream 使用示例 注意事项 二、QT操作TXT文件:清空内容并写入新数据 完整实现代…...

WordPress多语言插件安装与使用教程
WordPress多语言插件GTranslate的使用方法 在wordpress网站后台搜索多语言插件GTranslate并安装,安装完成、用户插件后开始设置,以下为设置方法: 1、先在后台左侧找到Gtranslate,进入到设置界面 2、选择要显示的形式,…...
互联网大厂Java求职面试:短视频平台大规模实时互动系统架构设计
互联网大厂Java求职面试:短视频平台大规模实时互动系统架构设计 面试背景介绍 技术总监(严肃脸): 欢迎来到我们今天的模拟面试,我是技术部的李总监,负责平台后端架构和高可用系统设计。今天我们将围绕一个…...

欣佰特科技|SenseGlove Nova2 力反馈数据手套:助力外科手术训练的精准触觉模拟
在医疗科技持续发展的背景下,虚拟现实(VR)技术正在改变外科手术培训的方式,而 SenseGlove Nova2 力反馈数据手套 在这一领域发挥着重要作用。 SenseGlove Nova2 力反馈数据手套 与 VirtualiSurg 手术模拟系统深度结合。其手部追踪…...
Axure元件动作七:移动、旋转、启用/禁用效果、置于顶层/底层详解
亲爱的小伙伴,在您浏览之前,烦请关注一下,在此深表感谢!如有帮助请订阅专栏! Axure产品经理精品视频课已登录CSDN可点击学习https://edu.csdn.net/course/detail/40420 案例视频: Axure移动、旋转、置于顶层底层、启用禁用 课程主题:移动、旋转、启用/禁用效果、置于顶…...

网络安全-等级保护(等保) 3-2-2 GB/T 28449-2019 第7章 现场测评活动/第8章 报告编制活动
################################################################################ GB/T 28449-2019《信息安全技术 网络安全等级保护测评过程指南》是规定了等级测评过程,是纵向的流程,包括:四个基本测评活动:测评准备活动、方案编制活…...
Flutter跨平台通信实战|3步打通Android原生能力,实现底层API调用!
当你的Flutter应用需要调用Android独有的硬件能力(如传感器、蓝牙模块)或系统级API时,如何与原生平台"对话"?本文手把手教你通过MethodChannel实现双向通信,让Flutter轻松驾驭Android底层能力! 一…...

IAM角色访问AWS RDS For MySQL
IAM角色访问AWS RDS For MySQL Tips: 写这篇文章,主要是用作记录;在AWS配置IAM RDS 角色权限访问,官方文档不怎么全,踩了一些坑… AWS云上配置 开启IAM身份验证 登录AWS控制台搜索并进入Databases管理页面选择数据库实例&#x…...
android property 系统
1.使用目的 目的都是为了测试。 减少编译流程。提高测试效率 2.使用方法流程 2.1 初始化默认值 方法一. 配置文件进行配置。 方法二. 手动初始化 setprop test.prop.id 12.2 获取键值并 property_get2.3 配置头文件 <cutils/properties.h>3.注意事项 3.1 关于无法…...