文档章节

查看线上日志常用命令

x
 xiaolyuh
发布于 09/21 16:41
字数 793
阅读 9
收藏 0

cat 命令(文本输出命令)

通常查找出错误日志 cat error.log | grep 'nick' , 这时候我们要输出当前这个日志的前后几行:

  • 显示file文件里匹配nick那行以及上下5行
cat error.log | grep -C 5 'nick'
  • 显示nick及前5行
cat error.log | grep -B 5 'nick'   
  • cat error.log | grep -A 5 'nick'
显示nick及后5行

less 命令(分页查看文件内容)

  • 分页查看日志,但是中文有乱码
less error.log
  • 直接定位到第100行
less +100g xx.log
  • 定位到最后一行
less +GG xx.log
  • 查找并高亮关键字
less fis.log.2018-05-20  | grep 2018052019004984219071028 -A 5 --color=auto

移动日志

  • G :到日志最后
  • g :到日志最前面
  • j/↑ :向前移动一行
  • k/↓ :向后移动一行
  • pgup :向上翻页
  • pgdn :向下翻页

搜索所需内容

  • /nick:在日志文件中查找 nick
  • n:向下查找下一个匹配的文本
  • N: 向上查找下一个匹配的文本

tail 命令(显示文件结尾)

  • 显示文件file的最后10行
tail file
  • 滚动输出日志
tail -f
  • 显示日志文件最后500行日志
tail -n 500 file
  • 显示日志从20行至文件末尾
tail +20 file 

grep 命令

grep 2018071018540800711006028 root.flog.2018-07-10-* | more

场景

按行号查看---过滤出关键字附近的日志

因为通常时候我们用grep拿到的日志很少,我们需要查看附近的日志.我是这样做的:

  1. 首先得到关键日志的行号
cat -n test.log |grep 地形  
  1. 得到"地形"关键字所在的行号是102行. 此时如果我想查看这个关键字前10行和后10行的日志:
cat -n test.log |tail -n +92|head -n 20

tail -n +92表示查询92行之后的日志 head -n 20 则表示在前面的查询结果里再查前20条记录

或者直接用这个命令

cat test.log | grep -C 10  地形 

那么按日期怎么查呢? 通常我们非常需要查找指定时间端的日志

sed -n '/2014-12-17 16:17:20/,/2014-12-17 16:17:36/p'  test.log

特别说明: 上面的两个日期必须是日志中打印出来的日志,否则无效. 关于日期打印,可以先 grep '2014-12-17 16:17:20' test.log 来确定日志中是否有该时间点

如果我们查找的日志很多,打印在屏幕上不方便查看, 有两个方法:

(1)使用more和less命令, 如:

cat -n test.log |grep "地形" | less

这样就分页打印了,通过点击空格键翻页

(2)使用 >xxx.txt 将其保存到文件中,到时可以拉下这个文件分析.如:

cat -n test.log |grep "地形"  >xxx.txt

查找并分页显示

在test.log文件中的最后一万行查找nick,并分页显示找到nick地方的上下5行

tail -n 10000 test.log | grep -C 5 nick| less

© 著作权归作者所有

x

xiaolyuh

粉丝 70
博文 128
码字总数 204225
作品 1
成都
高级程序员
私信 提问
linux 查看日志信息--less命令

线上出问题的时候,我们常用tail -n 或者 tail -f 或者grep 或者 vi cat等各种命令去查看异常信息, 但是日志是在不停地刷屏,tail是动态的在变的,我们往往期望从日志最后一行往前一页一页的...

HJCui
2018/07/20
131
0
Alibaba开源的Java诊断工具Arthas(阿尔萨斯) 安装文档

是Alibaba开源的Java诊断工具,深受开发者喜爱。 当你遇到以下类似问题而束手无策时,可以帮助你解决: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没...

西瓜1994
2018/09/28
663
0
阿里开源的 java 诊断工具—— Arthas

Arthas 是 阿里巴巴最近开源出来的一个针对 java 的工具,主要是针对 java 的问题进行诊断! 一、概述 这个工具可以协助你做下面这些事情: 这个类是从哪个 jar 包加载而来的? 为什么会报各...

Ryan-瑞恩
2018/09/18
24.9K
0
dwarfdump解析线上崩溃日志dSYM文件

1、dSYM文件:iOS构建时产生的符号表,它是内存地址与函数名,文件名,行号的映射表;iOS应用crash时也有堆栈,release版的应用,crash时的堆栈信息,全是二进制的地址信息;iOS平台中,dSYM文...

奋斗的青春年华
2018/08/22
747
0
在公司做的项目和自己在学校做的有什么区别?

前言 只有光头才能变强。 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 不知道大家还是学生的时候有没有这个问题:公司做的项目和自己在学校练手的项目有多...

Java3y
07/13
146
0

没有更多内容

加载失败,请刷新页面

加载更多

Podman 使用指南

> 原文链接:Podman 使用指南 Podman 原来是 CRI-O 项目的一部分,后来被分离成一个单独的项目叫 libpod。Podman 的使用体验和 Docker 类似,不同的是 Podman 没有 daemon。以前使用 Docker...

米开朗基杨
57分钟前
5
0
拯救 项目经理个人时间的5个技巧

优秀的项目经理都有一个共同点,那就是良好的时间管理能力。专业的项目经理会确保他们的时间投入富有成效,尽可能避免时间浪费。 时间管理叫做GTD,即Getting Things Done——“把事情做完”...

Airship
今天
7
0
LNMP环境介绍,Mariadb安装,服务管理,mariadb安装3

LNMP环境介绍 Nginx 处理的请求有两种,分为 静态与动态 图片,js,css,视频,音频,flash 等都是静态请求,这些数据都不是保存在数据库里面的 动态请求一般来说,需要的数据是在数据库里面...

doomcat
今天
2
0
前端技术之:Prisma Demo服务部署过程记录

安装前提条件: 1、已经安装了docker运行环境 2、以下命令执行记录发生在MackBook环境 3、已经安装了PostgreSQL(我使用的是11版本) 4、Node开发运行环境可以正常工作 首先需要通过Node包管...

popgis
今天
7
0
数组和链表

数组 链表 技巧一:掌握链表,想轻松写出正确的链表代码,需要理解指针获引用的含义: 对指针的理解,记住下面的这句话就可以了: 将某个变量赋值给指针,实际上就是将这个变量的地址赋值给指...

code-ortaerc
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部