自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

監(jiān)控利器:普羅米修斯監(jiān)控中間件(Nginx、Redis、MySQL等)

運(yùn)維
我們的產(chǎn)品目前使用到的中間件有 Nginx、Redis、RabbitMQ、MySql 等,本文介紹怎樣使用 Promtheus 來監(jiān)控這些中間件。

在《監(jiān)控利器:普羅米修斯介紹和安裝》中有一張圖,表明了 Prometheus 的數(shù)據(jù)走向,如下:

從圖中可以看出,監(jiān)控中間件的第一步就是安裝中間件的 exporter,安裝有兩種方式:下載安裝文件進(jìn)行安裝和使用 Docker 進(jìn)行安裝,下面示例中使用的是后者。

Nginx

我們產(chǎn)品的前端 Web 部署在 nginx 容器中,需要在容器的配置文件中進(jìn)行 nginx_status 模塊的設(shè)置,才能被 exporter 識別。nginx 配置文件添加下面代碼:

location /nginx_status {
        stub_status on;
        access_log off;
        allow all;
       # deny all;
 }
  • 為了測試方便直接設(shè)置為 allow all 了,實(shí)際可以根據(jù)需要進(jìn)行開放和禁用。

修改配置后,重啟 Web 容器,訪問 http://ip:port/nginx_status  ,出現(xiàn)下圖界面,說明配置生效:

執(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 端口,如下圖:

在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加  job 配置:

- job_name: 'nginx'
    static_configs:
      - targets: ['10.211.55.3:9113']

執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:

在 Grafana 中導(dǎo)入 12078 模板:

最終展示效果如下:

Redis

首先需要安裝 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 容器在一臺服務(wù)器,設(shè)置為同一網(wǎng)絡(luò)后,--redis.addr 就可以使用容器的內(nèi)部 IP 和端口。
  • 如果是分開部署,不需要設(shè)置 --network ,使用服務(wù)器 IP 和端口即可。

容器運(yùn)行成功后,瀏覽器訪問界面如下:

在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:

- job_name: 'reids'
    static_configs:
      - targets: ['10.211.55.3:9121']

執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:

在 Grafana 中導(dǎo)入 763 編號的模板:

最終展示效果如下:

RabbitMQ

首先需要安裝 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è)置在同一個網(wǎng)絡(luò)中,否則需要將 15672 映射出去。
  • -e RABBIT_USER、-e RABBIT_PASSWORD 為 RabbitMQ 的用戶名和密碼,默認(rèn)為 guest,也可以自行設(shè)置。

容器運(yùn)行成功后,瀏覽器訪問界面如下:

在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:

- job_name: 'rabbitmq'
    static_configs:
      - targets: ['10.211.55.3:9419']

執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:

在 Grafana 中導(dǎo)入 2121 編號的模板:

最終展示效果如下:

MySql

在 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'@'%';

在目錄 /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)建的賬號和密碼

執(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 文件的映射,會出現(xiàn)下面錯誤:

容器運(yùn)行成功后,瀏覽器訪問界面如下:

在 prometheus 的配置文件中進(jìn)行綁定,執(zhí)行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:

- job_name: 'mysql'
    static_configs:
      - targets: ['10.211.55.3:9104']

執(zhí)行命令 systemctl restart prometheus 重啟生效,可以訪問 http://10.211.55.3:9090/targets 查看狀態(tài),如果為 UP 說明 job 設(shè)置成功:

在 Grafana 中導(dǎo)入 7362 編號的模板:

最終展示效果如下:

責(zé)任編輯:姜華 來源: 不止dotNET
相關(guān)推薦

2020-12-30 08:47:04

Prometheus開源監(jiān)控

2021-09-30 10:59:11

DockerRedisExporter

2012-11-05 14:00:12

投影

2019-06-04 15:18:30

Web ServerNginx中間件

2023-10-16 12:25:48

2019-09-29 11:04:22

MySQL數(shù)據(jù)庫Atlas

2020-02-10 15:30:51

數(shù)據(jù)庫MySQLDAL

2023-02-28 22:52:47

2021-02-11 08:21:02

中間件開發(fā)CRUD

2011-05-24 15:10:48

2022-02-13 23:04:28

RedisRabbitMQKafka

2021-07-04 14:20:16

Redis中間件高性能

2018-07-29 12:27:30

云中間件云計(jì)算API

2018-02-01 10:19:22

中間件服務(wù)器系統(tǒng)

2016-11-11 21:00:46

中間件

2023-12-20 08:13:54

K8S監(jiān)控管理

2023-06-29 10:10:06

Rocket MQ消息中間件

2023-10-24 07:50:18

消息中間件MQ

2009-06-16 15:55:06

JBoss企業(yè)中間件

2012-11-30 10:21:46

移動中間件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號