05 . Prometheus監控Nginx
- 2020 年 6 月 21 日
- 筆記
- Prometheus, 監控
List
CentOS7.3
prometheus-2.2.1.linux-amd64.tar.gz
nginx-module-vts
節點名 | IP | 軟體版本 | 硬體 | 網路 | 說明 |
---|---|---|---|---|---|
Prometheus | 192.168.0.106 | list 裡面都有 | 2C4G | Nat,內網 | 測試環境 |
Nginx | 192.168.0.107 | list 裡面都有 | 2C4G | Nat,內網 | 測試環境 |
部署Prometheus
部署Promehteus請看我前面寫的文章
//www.cnblogs.com/you-men/p/12839535.html
部署Nginx
三個模組
nginx-module-vts:Nginx virtual host traffic status module,
# Nginx的監控模組,能夠提供JSON格式的數據產出。
nginx-vts-exporter:Simple server that scrapes Nginx vts stats and exports them via HTTP for Prometheus consumption。
# 主要用於收集Nginx的監控數據,並給Prometheus提供監控介面,默認埠號9913。
Prometheus:
# 監控Nginx-vts-exporter提供的Nginx數據,並存儲在時序資料庫中,可以使用PromQL對時序數據進行查詢和聚合。
Nginx-module-vts模組編譯
# nginx_vts_exporter依賴nginx-module-vts模組,安裝此模組無需任何其他依賴。模組與Nginx的版本兼容性如下:
1.11.x (last tested: 1.11.10)
1.10.x (last tested: 1.10.3)
1.8.x (last tested: 1.8.0)
1.6.x (last tested: 1.6.3)
1.4.x (last tested: 1.4.7)
部署nginx-module-vts
# 下載編譯模組
git clone git://github.com/vozlt/nginx-module-vts.git
# 編譯配置
--add-module=/path/to/nginx-module-vts
# 下載官方的軟體包並編譯進vts模組,例如:
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --with-http_sysguard_module --add-module=nginx-module-vts
# 安裝Nginx
#!/usr/bin/env bash
version="nginx-1.14.2.tar.gz"
user="nginx"
nginx=${version%.tar*}
path=/usr/local/src/$nginx
echo $path
if ! ping -c2 www.baidu.com &>/dev/null
then
echo "網路不通,無法安裝"
exit
fi
yum install -y gcc gcc-c++ openssl-devel pcre-devel make zlib-devel wget psmisc
if [ ! -e $version ];then
wget //nginx.org/download/$version
fi
if ! id $user &>/dev/null
then
useradd $user -M -s /sbin/nologin
fi
if [ ! -d /var/tmp/nginx ];then
mkdir -p /var/tmp/nginx/{client,proxy,fastcgi,uwsgi,scgi}
fi
tar xf $version -C /usr/local/src
cd $path
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --add-module=/usr/local/src/nginx-1.14.0/nginx-module-vts/ && make && make install
配置nginx.conf
http {
vhost_traffic_status_zone;
vhost_traffic_status_filter_by_host on;
server {
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
配置建議
1 . 打開vhost過濾:
vhost_traffic_status_filter_by_host on;
開啟此功能,在Nginx配置有多個server_name的情況下,會根據不同的server_name進行流量的統計,否則默認會把流量全部計算到第一個server_name上2 . 在不想統計流量的server區域禁用vhost_traffic_status,配置示例:
server {
...
vhost_traffic_status off;
...
}
假如nginx沒有規範配置server_name或者無需進行監控的server上,那麼建議在此vhost上禁用統計監控功能。否則會出現「127.0.0.1」,hostname等的域名監控資訊。
查看監控數據
安裝完vts模組後,可以通過nginx status介面進行監控數據的查看,比如://127.0.0.1/status:
配置Nginx-vts-exporter
exporter會收集nginx性能指標的JSON格式數據,並匯總後暴露監控介面給Prometheus。
它的安裝使用很簡單,開箱即用
下載軟體包
wget -c //github.com/hnlq715/nginx-vts-exporter/releases/download/v0.9.1/nginx-vts-exporter-0.9.1.linux-amd64.tar.gz
配置運行
tar xvf nginx-vts-exporter-0.9.1.linux-amd64.tar.gz
nginx-vts-exporter-0.9.1.linux-amd64/nginx-vts-exporter -nginx.scrape_timeout 10 -nginx.scrape_uri //127.0.0.1/status/format/json
# 推薦exporter和nginx安裝在同一台機器上,如果不在同一台主機,把scrape_uri改為nginx主機的地址。
# nginx_vts_exporter的默認埠號:9913,對外暴露監控介面//xxx:9913/metrics.
# 我們可以訪問瀏覽器 IP:9913
將node exporter配置到prometheus里
# 配置Prometheus,收集node exporter的數據
# 可以看到node exporter啟動後也就是暴露了9100埠,並沒有把數據傳到prometheus,
# 我們還需要在prometheus中配置,讓prometheus去pull這個介面的數據。
# 我們去監控主機編輯prometheus.yml文件,修改最後幾行,然後重啟服務
vim /usr/local/prometheus/prometheus.yml
scrape_configs:
- job_name: 'prometheus'
static_configs:
- targets: ['localhost:9090']
- job_name: 'nginx'
static_configs:
- targets: ['192.168.0.107:9913']
# node節點的targets處的IP填寫你要監控的node的IP.
systemctl restart prometheus
# 我們登錄到Prometheus主機,看下這個節點是不是up狀態
Grafana安裝
此處我們拿prometheus做例子,雖然說prometheus能展示一些圖表,但對比Grafana,那只是過家家,接下來我們在同一個伺服器安裝Grafana服務,用來展示prometheus收集到的數據
下載並解壓安裝包
wget //dl.grafana.com/oss/release/grafana-6.4.2.linux-amd64.tar.gz
tar xvf grafana-6.4.2.linux-amd64.tar.gz -C /usr/local/
ln -s /usr/local/grafana-6.4.2/ /usr/local/grafana
創建grafana用戶及數據存放目錄
useradd -s /sbin/nologin -M grafana
mkdir /data/grafana
mkdir /data/grafana/plugins
mkdir /data/grafana/provisioning
mkdir /data/grafana/data
mkdir /data/grafana/log
chown -R grafana:grafana /usr/local/grafana/
chown -R grafana:grafana /data/grafana/
修改配置文件
vim /usr/local/grafana/conf/defaults.ini
data = /data/grafana/data
logs = /data/grafana/log
plugins = /data/grafana/plugins
provisioning = /data/grafana/conf/provisioning
把grafana-server添加到systemd中
vim /usr/lib/systemd/system/grafana-server.service
[Unit]
Description=Grafana
After=network.target
[Service]
User=grafana
Group=grafana
Type=notify
ExecStart=/usr/local/grafana/bin/grafana-server -homepath /usr/local/grafana
Restart=on-failure
[Install]
WantedBy=multi-user.target
systemctl start grafana-server && systemctl enable graana-server
啟動服務,並用web訪問//IP:3000,默認3000埠,admin/admin
添加數據源
# grafana雖然已經安裝好了,但是這個時候還沒有數據,沒辦法作圖。
# 下面我們把grafana和prometheus關聯起來,也就是在grafana中添加添加數據源。
# 在配置頁面點擊添加數據源,然後選擇prometheus,輸入prometheus服務的參數即可。