Nginx網站伺服器在生產環境中執行的時候需要進行實時監控。實際上,諸如Nagios, Zabbix, Munin 的網路監控軟體是支援 Nginx 監控的。
如果你不需要以上軟體提供的綜合性報告或者長期資料統計功能,只是需要一種快速簡便的辦法去監控 Nginx 伺服器的請求的話,我建議你採用一個叫 ngxtop 的命令列工具。
你馬上就會發現 ngxtop 從介面和名稱都借鑑了著名的top命令。ngxtop 是通過分析 Nginx 或者其他的日誌檔案,使用類似 top 命令的介面實時展示出來的。你可以說你知道的其他高階監控工具,但是在簡潔這方面 ngxtop 無疑是最好的。簡單就意味著不可替代。
本指南中,我將介紹如何使用 ngxtop 實時監控 Nginx 網站伺服器。
Linux 上安裝 ngxtop
首先在 Linux 系統中安裝依賴庫 pip(LCTT譯註:ngxtop是用python編寫的)。
然後使用如下命令安裝 ngxtop。
1 |
$ sudo pip install ngxtop |
ngxtop 使用
基本使用方法如下:
1 2 3 |
ngxtop [options] ngxtop [options] (print|top|avg|sum) <var> ngxtop info |
這裡是一些通用選項。
- -l : 指定日誌檔案的完整路徑 (Nginx 或 Apache2)
- -f : 日誌格式
- –no-follow: 處理當前已經寫入的日誌檔案,而不是實時處理新新增到日誌檔案的日誌
- -t : 更新頻率
- -n : 顯示行號
- -o : 排序規則(預設是訪問計數)
- -a …, –a …: 新增表示式(一般是聚合表示式如: sum, avg, min, max 等)到輸出中。
- -v: 輸出詳細資訊
- -i : 只處理符合規則的記錄
以下是一些內建變數,他們的含義不言自明。
- bodybytessend
- http_referer
- httpuseragent
- remote_addr
- remote_user
- request
- status
- time_local
使用 ngxtop 監控 Nginx
ngxtop 預設會從其配置檔案 (/etc/nginx/nginx.conf) 中查詢 Nginx 日誌的地址。所以,監控 Nginx ,執行以下命令即可:
1 |
$ ngxtop |
這將會列出10個 Nginx 服務,按請求數量排序。
顯示前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,ngtop 還可以處理其他的日誌檔案,比如 Apache 的訪問檔案。使用以下命令監控 Apache 伺服器:
1 |
$ tail -f /var/log/apache2/access.log | ngxtop -f common |