在 Ubuntu 15.04 上安装 Justniffer
================================================================================
### 简介 ###
![](http://1426826955.rsc.cdn77.org/wp-content/uploads/2015/09/monitoring1.jpg)

[Justniffer][1] 是一个可用于替代 Snort 的网络协议分析器。它非常流行,可交互式地跟踪/探测一个网络连接。它能从实时环境中抓取流量,支持 “lipcap” 和 “tcpdump” 文件格式。它可以帮助用户分析一个用 wireshark 难以抓包的复杂网络。尤其是它可以有效的帮助你分析应用层流量,能提取类似图像、脚本、HTML 等 http 内容。Justniffer 有助于理解不同组件之间是如何通信的。

### 功能 ###

Justniffer 可以收集一个复杂网络的所有流量而不影响系统性能,这是 Justniffer 的一个优势,它还可以保存日志用于之后的分析,Justniffer 其它一些重要功能包括:

1. 可靠的 TCP 流重建

	它可以使用主机 Linux 内核的一部分用于记录并重现 TCP 片段和 IP 片段。

2. 日志

	保存日志用于之后的分析,并能自定义保存内容和时间。

3. 可扩展

	可以通过外部的 python、 perl 和 bash 脚本扩展来从分析报告中获取一些额外的结果。

4. 性能管理

	基于连接时间、关闭时间、响应时间或请求时间等提取信息。

### 安装 ###

Justniffer 可以通过 PPA 安装:

运行下面命令添加库:

    $ sudo add-apt-repository ppa:oreste-notelli/ppa

更新系统:

    $ sudo apt-get update

安装 Justniffer 工具:

    $ sudo apt-get install justniffer

make 的时候失败了,然后我运行下面的命令并尝试重新安装服务

    $ sudo apt-get -f install

### 示例 ###

首先用 -v 选项验证安装的 Justniffer 版本,你需要用超级用户权限来使用这个工具。

    $ sudo justniffer -V

示例输出:

![j](http://www.unixmen.com/wp-content/uploads/2015/09/j.png)

**1、 以类似 apache 的格式导出 eth1 接口流量,显示到终端**

    $ sudo  justniffer -i eth1

示例输出:

![Selection_001](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0013.png)

**2、 可以用下面的选项跟踪正在运行的 tcp 流**

    $ sudo  justniffer -i eth1 -r

示例输出:

![Selection_002](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0023.png)

**3、 获取 web 服务器的响应时长**

    $ sudo justniffer -i eth1 -a " %response.time"

示例输出:

![Selection_003](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0033.png)

**4、 使用 Justniffer 读取一个 tcpdump 抓取的文件**

首先,用 tcpdump 抓取流量。

    $ sudo tcpdump -w /tmp/file.cap -s0 -i eth0

然后用 Justniffer 访问数据

    $ justniffer -f file.cap

示例输出:

![Selection_005](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0056.png)

**5、 只抓取 http 数据**

    $ sudo justniffer -i eth1 -r -p "port 80 or port 8080"

示例输出:

![Selection_006](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0064.png)

**6、  获取一个指定主机 http 数据**

    $ justniffer -i eth1 -r -p "host 192.168.1.250 and tcp port 80"

示例输出:

![Selection_007](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0074.png)

**7、 以更精确的格式抓取数据**

当你输入 **justniffer -h** 的时候你可以看到很多用于以更精确的方式获取数据的格式关键字

    $ justniffer -h

示例输出:

![Selection_008](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0083.png)

让我们用 Justniffer 根据预先定义的参数提取数据

    $ justniffer -i eth1 -l "%request.timestamp %request.header.host %request.url %response.time"

示例输出:

![Selection_009](http://www.unixmen.com/wp-content/uploads/2015/09/Selection_0094.png)

其中还有很多你可以探索的选项。

### 总结 ###

Justniffer 是一个很好的用于网络测试的工具。在我看来对于那些用 Snort 来进行网络探测的用户来说,Justniffer 是一个更简单的工具。它提供了很多 **格式关键字** 用于按照你的需要精确地提取数据。你可以用 .cap 文件格式记录网络信息,之后用于分析监视网络服务性能。

**参考资料:**

- [Justniffer 官网][2]

--------------------------------------------------------------------------------

via: http://www.unixmen.com/install-justniffer-ubuntu-15-04/

作者:[Rajneesh Upadhyay][a]
译者:[ictlyh](http://mutouxiaogui.cn/blog)
校对:[wxy](https://github.com/wxy)

本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出

[a]:http://www.unixmen.com/author/rajneesh/
[1]:http://sourceforge.net/projects/justniffer/?source=directory
[2]:http://justniffer.sourceforge.net/