如何从命令行实时监控Nginx Web服务器?

译文
运维 系统运维
一旦Nginx Web服务器在生产环境下搭建并运行起来,你就希望能够实时监测其活动。实际上,普通的网络监控软件都可以提供支持实时监控Nginx的功能,比如Nagios、Zabbix和Munin。本教程中将介绍如何借助ngxtop,实时监控Nginx Web服务器。

【51CTO精选译文】一旦Nginx Web服务器在生产环境下搭建并运行起来,你就希望能够实时监测其活动。实际上,普通的网络监控软件都可以提供支持实时监控Nginx的功能,比如Nagios、Zabbix和Munin。

不过,如果你不需要这类工具所提供的综合报告功能或长期统计数字,只想快速、简便地监控对Nginx Web服务器提出的请求,那么我会建议使用一款名为ngxtop的命令行工具

你一眼就会发现,无论名称还是界面,ngxtop的灵感均源自大名鼎鼎的top命令。ngxtop的功能就是,分析Nginx访问日志文件(以及其他日志文件,比如Apache2日志),并通过类似top的界面,实时显示分析后所得的结果。你可能吹嘘自己的综合监控工具拥有各种各样的所需功能,但说到简洁性,肯定比不过ngxtop,而简洁性是不可忽视的一大优点。

我在本教程中将介绍如何借助ngxtop,实时监控Nginx Web服务器。

将ngxtop安装在Linux上

首先,将pip安装在你的Linux系统上,这是ngxtop的一个前提条件。

然后安装ngxtop,如下所示。

  1. $ sudo pip install ngxtop 

ngxtop的使用方法

ngxtop的基本使用方法如下:

  1. ngxtop [options] 
  2. ngxtop [options] (print|top|avg|sum) <var> 
  3. ngxtop info 

下面是一些常用选项。

  • -l <file>:访问日志文件(Nginx或Apache2)的完整路径
  • -f <format>:访问日志的格式
  • --no-follow:处理当前的日志文件快照,而不是实时写入到日志文件的新行
  • -t <seconds>:更新间隔时间
  • -n <number>:所显示的行数
  • -o <var>:排序标准(默认标准:数量)
  • -a <exp> ..., --a <exp> ...::将表达式(必须是聚合表达式:sum、avg、min和max等)添加到输出
  • -v:详细输出
  • -i <filter-expression>:只处理与过滤器匹配的记录

下面是一些内置变量(用上面的<var>来表示)。它们的含义不言自明。

  • body_bytes_send
  • http_referer
  • http_user_agent
  • remote_addr
  • remote_user
  • request
  • status
  • time_local

使用ngxtop监控Nginx

默认情况下,ngxtop会设法从其配置文件(/etc/nginx/nginx.conf)查明Nginx访问日志的位置。因而,想监控Nginx,只要运行这个命令:

  1. $ ngxtop 

它会显示由Nginx处理的10个请求,按请求数量排序。

想显示前20个最频繁的请求,只要运行这个命令:

  1. $ ngxtop -n 20 

想获得关于Nginx的信息(包括可用变量信息),只要运行这个命令:

  1. $ ngxtop info 

如果你愿意,也可以定制所要显示的变量。为此,只要列出你感兴趣的变量。"print"命令会显示一个个请求。

  1. $ ngxtop print request http_user_agent remote_addr 

想显示客户机的最常出现的IP地址,只要运行这个命令:

  1. $ ngxtop top remote_addr 

想显示状态代码是404的请求,只要运行这个命令:

  1. $ ngxtop -i 'status == 404' print request status 

除了Nginx外,ngxtop还能够处理其他日志文件,比如Apache访问日志。想监控Apache Web服务器,只要使用这个命令:

  1. $ tail -f /var/log/apache2/access.log | ngxtop -f common 

原文链接:http://xmodulo.com/2014/06/monitor-nginx-web-server-command-line-real-time.html

责任编辑:黄丹 来源: 51CTO.com
相关推荐

2014-06-17 09:49:07

Ngxtop实时监控Nginx

2012-02-08 16:37:36

ibmdw

2020-12-06 08:00:46

scanimage命令行Linux

2016-12-15 08:30:02

Linux命令

2021-08-17 09:35:26

Linux命令Nginx

2019-08-27 08:00:10

OpenStack命令虚拟机

2019-07-15 05:50:19

Linux命令行VirtualBox版

2019-01-22 13:46:01

LinuxUnix系统命令行

2014-10-22 12:03:14

Linux嗅探HTTP

2020-04-17 13:08:11

Nginx命令开发Linux

2021-09-18 09:19:21

Linux

2023-10-17 07:51:37

MySQLQPS优化

2020-04-15 20:57:57

NginxWeb服务器

2014-04-10 10:10:16

KVMDebianUbuntu

2017-12-27 10:18:09

ApacheNginx服务器

2010-03-30 18:26:07

Nginx Web服务

2023-08-01 13:31:18

模型Alpacaicuna

2018-06-19 16:05:27

LinuxStratis存储

2020-10-31 08:20:39

curl命令命令行互联网

2018-05-24 14:20:01

数据库MySQL命令行
点赞
收藏

51CTO技术栈公众号