Java程序员修炼之道 之 Logging(3/3) - 怎么分析Log

时间:2014-09-17 23:21:13   收藏:0   阅读:441

1. 说明

作为一个程序员我们经常要做一件事情:获取某个Log文件,从其中找出自己想要的信息。本文总结了我在工作中使用了哪些工具来分析Log文件获取我想要的信息,我最近几年的工作环境都是服务器在Linux上,工作机是Windows, 所以我用的工具主要是Linux上的一些命令行工具,当然他们在Windows上也可以用,具体看下面的工具篇。
先声明,我只是非常普通的Linux用户,所以如果有些Linux命令或者工具用的不高效,请大家教育我。

题外话:我的观点是作为一个Java程序员,只需要在自己工作所需要的范围内了解所使用的操作系统就可以了,成为专家固然好,但是不是必要的,譬如:我天天用Windows,但是始终不知道如何通过编辑组策略或者是注册表的方式调网络连接数的最大值,反正几乎所有的优化工具都有这个功能。

2. 工具

3. 分析Log

3.1 搜索文本

分析Log首先就是找到你所需要的Log,一般情况下我们所需要的Log是这么定位的

  1. 根据异常信息或者请求信息找到对应的那一行
  2. 根据该行的时间、线程名称、关键字等信息找到上下文中相关的Log

下面我们分别说一下上面这两步应该如何做

3.1.1 找到对应的那一行,那一些文件

一般情况下我们在开始分析Log的时候会有这些信息辅助我们进行搜索

3.1.1.1 如果知道Log是在某一个具体的文件的话

我一般是使用vi 只读模式打开该文件(假设该文件名为access.log)
vi -R access.log
进去后让它显示一下行号:
:set nu

跳到第一行:
gg
或者是
1G

跳到最后一行:
0G
或者是
G

跳到第11行:
11G

从文件头往后面搜索字符串Hello World:
:/Hello World

从文件尾往前搜索字符串Hello World:
:?Hello World

跳到下一个符合搜索条件的地方:
n

跳到上一个符合搜索条件的地方:
N

vi里面用Go的缩写字母g跳来跳去, 字母n是Next的缩写退出vi的命令是:
:q!

3.1.1.2 如果不知道是哪个文件的话

我一般是使用grep命令例子如下:把搜索结果打印到屏幕上,用空格键翻页
grep -nR "Hello World" ./*.log | more
把搜索结果打印到文件helloWorld.log中
grep -nR "Hello World" ./*.log > helloWorld.log

3.1.2 找上下文

按照上面的步骤,找到线索了,如果干扰信息不多的话,你上下浏览可以了。那么如果干扰信息较多,我一般通过综合使用以下几种方式来获取自己所需要的不带干扰信息的日志。

3.2 日志分析

除了在Log中发现线索之外,有的时候还需要对日志进行批量的分析,我碰到过的比如分析某种错误出现的时间、出现该错误的相关的id等等。需要用到一些统计之类的东西。

3.2.1 简单情况

简单的我一般把每个场景萃取一行到一个文件中,然后使用wc(别笑,它是word count的缩写)命令来计算行数,如下所示
wc -l result.log
复杂的我一般是使用Excel或者是金山WPS来进行文件分析。

3.2.2 使用Excel或者金山WPS进行文件分析

  1. 首先是先新建一个工作表
  2. 然后把要分析的文本拷贝进去
  3. 然后反复的使用 *分列* (菜单:数据->分列)功能把日志文件拆分成一个表格
  4. 然后再使用过滤排序数据透视图等功能来进行分析

3.3 其他一些有用的命令

tail -f abc.log
tail -f ./*.log
head -20 abc.log
tail -50 abc.log

原文:http://blog.csdn.net/justfly/article/details/39349293

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!