監(jiān)控利器:普羅米修斯監(jiān)控中間件(Nginx、Redis、MySql 等)
我們的產(chǎn)品目前使用到的中間件有 Nginx、Redis、RabbitMQ、MySql 等,本文介紹怎樣使用 Promtheus 來監(jiān)控這些中間件。
在《監(jiān)控利器:普羅米修斯介紹和安裝》中有一張圖,表明了 Prometheus 的數(shù)據(jù)走向,如下:
從圖中可以看出,監(jiān)控中間件的第一步就是安裝中間件的 exporter,安裝有兩種方式:下載安裝文件進(jìn)行安裝和使用 Docker 進(jìn)行安裝,下面示例中使用的是后者。
Nginx
1、我們產(chǎn)品的前端 Web 部署在 nginx 容器中,需要在容器的配置文件中進(jìn)行 nginx_status 模塊的設(shè)置,才能被 exporter 識(shí)別。nginx 配置文件添加下面代碼:
location /nginx_status {
stub_status on;
access_log off;
allow all;
# deny all;
}
-
為了測試方便直接設(shè)置為 allow all 了,實(shí)際可以根據(jù)需要進(jìn)行開放和禁用。
2、修改配置后,重啟 Web 容器,訪問 http://ip:port/nginx_status ,出現(xiàn)下圖界面,說明配置生效:
3、執(zhí)行下面的命令進(jìn)行 nginx-exporter 容器的安裝:
docker pull nginx/nginx-prometheus-exporter
docker run -p 9113:9113 -d --restart=always --name nginx-exporter nginx/nginx-prometheus-exporter -nginx.scrape-uri http://10.211.55.3:90/nginx_status
-
http://192.168.3.78/nginx_status 為被監(jiān)控的 nginx 服務(wù)器的地址。
容器運(yùn)行后,訪問 9113 端口,如下圖:
4、在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:
- job_name: 'nginx'
static_configs:
- targets: ['10.211.55.3:9113']
5、執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:
6、在 Grafana 中導(dǎo)入 12078 模板:
7、最終展示效果如下:
Redis
1、首先需要安裝 redis_exporter ,執(zhí)行下面命令進(jìn)行鏡像的下載和安裝:
docker pull oliver006/redis_exporter
# 如果 redis 沒有密碼執(zhí)行下面命令
docker run -d --name redis_exporter -p 9121:9121 --network s2v9_test_s2_net oliver006/redis_exporter --redis.addr redis://172.66.9.9:6379
# 如果 redis 有密碼執(zhí)行下面命令
docker run -d --name redis_exporter -p 9121:9121 --network s2v9_test_s2_net oliver006/redis_exporter --redis.addr redis://172.66.9.9:6379 --redis.password '000000'
-
上面命令中 --network s2v9_test_s2_net 為 redis 容器所在的網(wǎng)絡(luò),因?yàn)槲业?exporter 容器和 redis 容器在一臺(tái)服務(wù)器,設(shè)置為同一網(wǎng)絡(luò)后,--redis.addr 就可以使用容器的內(nèi)部 IP 和端口。 -
如果是分開部署,不需要設(shè)置 --network ,使用服務(wù)器 IP 和端口即可。
2、容器運(yùn)行成功后,瀏覽器訪問界面如下:
3、在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:
- job_name: 'reids'
static_configs:
- targets: ['10.211.55.3:9121']
4、執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:
5、在 Grafana 中導(dǎo)入 763 編號(hào)的模板:
6、最終展示效果如下:
RabbitMQ
1、首先需要安裝 redis_exporter ,執(zhí)行下面命令進(jìn)行鏡像的下載和安裝:
docker pull kbudde/rabbitmq-exporter:latest
docker run -d -p 9419:9419 --name rabbitmq-exporter --network s2v9_test_s2_net -e RABBIT_URL=http://172.66.9.8:15672 -e RABBIT_USER=Ican -e RABBIT_PASSWORD=000000 kbudde/rabbitmq-exporter
-
-e RABBIT_URL=http://172.66.9.8:15672 ,這里設(shè)置的是 RabbitMQ 容器的內(nèi)部 IP,所以必須設(shè)置在同一個(gè)網(wǎng)絡(luò)中,否則需要將 15672 映射出去。 -
-e RABBIT_USER、-e RABBIT_PASSWORD 為 RabbitMQ 的用戶名和密碼,默認(rèn)為 guest,也可以自行設(shè)置。
2、容器運(yùn)行成功后,瀏覽器訪問界面如下:
3、在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:
- job_name: 'rabbitmq'
static_configs:
- targets: ['10.211.55.3:9419']
4、執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:
5、在 Grafana 中導(dǎo)入 2121 編號(hào)的模板:
6、最終展示效果如下:
MySql
1、在 mysql 數(shù)據(jù)庫中創(chuàng)建 exporter 賬戶,并設(shè)置權(quán)限:
CREATE USER 'exporter'@'%' IDENTIFIED BY 'Aa123456';
GRANT PROCESS, REPLICATION CLIENT ON *.* TO 'exporter'@'%';
GRANT SELECT ON performance_schema.* TO 'exporter'@'%';
2、在目錄 /root/exporter/config/mysql 中創(chuàng)建 .my.cnf 文件,文件內(nèi)容如下:
[client]
host=172.66.9.2
port=3306
user=exporter
password=Aa123456
-
host 配置為 mysql 數(shù)據(jù)庫的容器 IP -
user 和 password 配置為新創(chuàng)建的賬號(hào)和密碼
3、執(zhí)行下面命令安裝 mysqld-exporter :
docker pull prom/mysqld-exporter
docker run -d -p 9104:9104 --network s2v9_test_s2_net --restart="always" -v /root/exporter/config/mysql/.my.cnf:/.my.cnf prom/mysqld-exporter
如果沒有 .my.cnf 文件的映射,會(huì)出現(xiàn)下面錯(cuò)誤:
4、容器運(yùn)行成功后,瀏覽器訪問界面如下:
5、在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:
- job_name: 'mysql'
static_configs:
- targets: ['10.211.55.3:9104']
6、執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:
7、在 Grafana 中導(dǎo)入 7362 編號(hào)的模板:
8、最終展示效果如下:
