对于 Linux 下使用 Apache 作为 Web 服务器来说,大家也许经常会需要查看服务器的实时运行情况,比如哪些 URL 的访问量最大,服务器每秒的请求数,等等。 apachetop 就是这样一个工具, 能够让你实时的监测 apache 服务器的运行状况。
apachetop 是一个命令行工具,它的运行原理是通过分析 apache 服务器的日志文件,来向用户展示服务器的运行情况。
- 安装与使用 apachetop
以 CentOS 为例,输入如下命令:
1
|
|
- 使用 apachetop
安装完成后,可以在命令行中输入:
1
|
|
如果成功找到了日志文件,apachetop 就会在命令行中显示类似如下的内容,并且这些内容会自动刷新:
1 2 3 4 5 6 7 8 9 10 11 12 |
|
上面的命令行输出,向我们展示了 apache 服务器当前的运行状况,我们可以逐行进行分析:
首先,这行中的 last hit 列出了最后点击(也就是请求)的时间, atop runtime 代表 apachetop 已经运行的时间,这行最后的那个是当前的时间。
1
|
|
接下来,这行列出了自从 apachetop 开始运行以来所有的请求次数,以及每秒平均的请求次数, 接收到的字节数,每秒接收的字节数,每次请求平均的字节数。 第二行代表服务端发出的HTTP响应代码情况,例如,2xx 表示请求成功的响应代码发送的次数,比如 200 响应,4xx 代表比如 404 这类的响应次数。
1 2 |
|
下面这两行各个属性所表示的含义和上面那两行是一样的,唯一不同的是它们跨越的时段不一样。 前两行是统计自从 apachetop 启动以来所有的请求,而这两行默认统计的是 30 秒之内的请求。
1 2 |
|
下面这些行就是具体每一个 URL 的请求状况了:
1 2 3 4 5 |
|
这里面列出了在指定时段内对每一个 URL 分别的请求数量,每秒的平均请求次数,这些请求的字节数,以及每秒平均的字节数。
到这里,我们了解了 apachetop 最基本的使用方法,下面我们将更进一步的介绍它更多的特性。
*apachetop 的各种视图模式
如果仔细看一下的话,你会发现 URL 列表的第一行多了一个星号:
1 2 |
|
这个星号代表你选中了当前这一行,你可以按键盘的上下键来选择其他行,当你选中一行后,按下 → 键,就可以进入该条 URL 的详细信息界面:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
在这个界面中,你可以看到对于该条 URL,请求它的 IP 都是什么。看完这个之后,你可以按下 ← 按键,回到列表视图。
在列表视图中,你可以按 d 键,在 URL/Referrer/Host 这三个列表视图之间进行切换:
1 2 3 4 5 6 7 8 9 10 11 |
|
在上面的 HOST 视图中,我们可以看到IP的来源情况,而且可以按下 → 键进入详细视图查看该条 IP 都访问过哪些 URL。
1 2 3 4 5 6 7 8 9 |
|
在上面的 REFERRER 视图中, 我们可以看到各个网站的来源情况,这对于分析链接来源非常有用。
*为 URL 列表添加过滤器
如果你的 URL 列表中的链接太多了,你可以添加一些过滤器来对这个列表进行筛选,从而找到你需要检测的 URL。
在 URL 列表视图中,按下 f 键,这时你会看到这样一个菜单:
1
|
|
再按下 a 键,添加一个过滤器,这时会让你选择过滤器的类型:
1
|
|
我们按下 u 键,选择 URL 过滤器, 然后输入你的过滤条件,再按下回车键,这时候,列表视图中我们就可以看到筛选后的内容了。
还有一些其他的选项,比如还可以设置如何对列表视图进行排序, 我们可以在列表视图中按下 h 键来查看运行时的帮助信息:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
上面的帮助文档列出了在运行时所有可以执行的操作,比如我们前面提到的 d 键切换视图, f 键添加过滤器,还有一个 s 键,可以用来对列表进行排序等等。
-
apachetop 的命令行参数
-
默认情况下, apachetop 会在 apache http 服务器的默认日志路径上面来查找日志文件,以便于通过这些日志文件来生成实时检测报告,但如果你的日志文件没有在默认的位置,那么 apachetop 就没办法 找到它了。 这时候可以使用 -f 参数来明确的指定日志文件的位置:
1
|
|
- apachetop 的列表视图,默认情况下是不显示出 URL 参数的, 如果你还需要显示 URL 参数,那么可以使用 -q 参数:
1
|
|
- apachetop 会使用一个缓存区域来存放一定数量的日志记录,以生成最终的实时检测报表,默认情况下会以保存 30 秒之内的请求记录。 它提供了两个参数可以让你来控制这个缓存区的大小。
-H num 以请求数来计算,比如你想让 apachetop 记录 1000 次点击之内的情况:
1
|
|
-T sec 以时间进行来计算,比如记录 20秒之内的请求:
1
|
|
还有更多的命令行参数, 可以通过 -help 参数来查看:
1
|
|