热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

prometheus+grafana+pushgateway+nodeexporter+consul搭建监控系统

目录一.总览二.安装prometheusgrafana三.安装一个exporter四.pushgateway安装五.servicediscovery之consul六.a

目录

一.总览

二.安装prometheus + grafana

三. 安装一个exporter

四.pushgateway安装

五. service discovery之consul

六.alertmanager

七.Grafana嵌入到自己的项目

八.Grafana API报告的导出为PDF




一.总览

prometheus提供的一张图

这张图包含几部分

1.监控grafana

2.pull metrics:(1)pushgateway (2)exporters

3.服务发现service discovery,主要是动态发现exporters

4.告警alertmanager

5.prometheus server

Prometheus 架构图


二.安装prometheus + grafana

1.在/ops/prometheus下建立文件prometheus.yml 和targets.json(这个可以不用,也是用于动态添加targets)

编辑文件vim prometheus.ymlglobal:scrape_interval: 1sevaluation_interval: 1sscrape_configs:- job_name: prometheusstatic_configs:- targets: ['localhost:9090']labels:instance: prometheus- job_name: pushgateway #安装的pushgateway使用该配置项metrics_path: '/metrics'static_configs:- targets: ['192.168.253.215:9091'] # 地址修改为实际地址labels:instance: pushgatewayhonor_labels: true- job_name: nodesfile_sd_configs:#提供文件方式动态添加targets- files:- 'targets.json'refresh_interval: 10s编辑文件 targets.json ,node_exporter会用该配置项
[{"targets": ["192.168.253.215:9400"],"labels": {"job": "node"}}
]

2.启动prometheus

docker run  -d   -p 9090:9090   -v /opt/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml    -v /opt/prometheus/targets.json:/etc/prometheus/targets.json    prom/prometheus

启动后访问地址 http://192.168.253.215:9090/

3.启动grafana

docker run -d \-p 3000:3000 \--name=grafana \-v /opt/grafana-storage:/var/lib/grafana \grafana/grafana

访问地址 

http://192.168.253.215:3000/

3.在grafana添加prometheus,点击save保存就可以

 

4.grafana导入已经存在的图表配置

在这里下载一个模板locust :https://grafana.com/grafana/dashboards/12081

导入

5.grafana刷新时间是最小5秒,配置每秒刷新一次,注:网上说低版本有bug,该配置项不起作用

进入docker 

docker exec  -it --user root  b1dbe0b4357a /bin/bash

修改配置,修改后重启docker

vi /etc/grafana/grafana.ini搜min_refresh_interval改为1s
由:
;min_refresh_interval = 5s
改为:
min_refresh_interval = 1s

6.打开grafana相关的工程,配置刷新时间为1s

 

非docker安装

grafana下载包:https://grafana.com/grafana/download?platform=linux
./grafana-server -config=/home/ops/grafana-7.3.5/conf/grafana.ini cfg:default.paths.plugins=/home/ops/grafana-7.3.5/plugins
 


三. 安装一个exporter

1.下载地址 https://github.com/prometheus/node_exporter/releases

2.启动 ./node_exporter --web.listen-address=":9400"

3. 前面prometheus已经配置了9400这个ip地址的targets,所有现在应该已经开始监控

4. 随便打开一个面板图,在面板最下面添加一个【Query】,选择【Metrics】=》【node】=》【node_load1】,输入框可以根据条件过滤 node_load1{instance="192.168.253.215:9400", job="node"}

5.修改面板的刷新时间是1S


四.pushgateway安装

拓扑图

1. docker 安装 docker run -d -p 9091:9091 prom/pushgateway

2.启动后可以访问 http://192.168.253.215:9091/

3.推一条指标给pushgateway

cat <locust_stats_avg_content_length 2398.283
EOF

4.在上面prometheus已经配置好pushgateway&#xff0c;如果没配&#xff0c;先配置Prometheus

5.删除指标&#xff0c;也可以去界面删除  curl -X DELETE http://192.168.253.215:9091/metrics/job/some_job/instance/some_instance

6.python​用 prometheus_client实现参考链接&#xff1a;

https://www.cnblogs.com/xiao987334176/p/9933963.html

 


五. service discovery之consul

1.安装consul

docker run --name consul -d -p 8500:8500 consul

2.配置prometheus

- job_name: &#39;consul&#39;consul_sd_configs:- server: &#39;192.168.253.215:8500&#39;services: []relabel_configs:- source_labels: [__meta_consul_tags]regex: .*dev.*action: keep

3.向consul注册服务

curl -X PUT -d &#39;{"id": "test1","name": "test1","address": "192.168.253.215","port": 9500,"tags": ["dev"],"checks": [{"http": "http://192.168.253.215:9500/","interval": "5s"}]}&#39; http://192.168.253.215:8500/v1/agent/service/register注销服务
curl -X PUT http://192.168.253.215:8500/v1/agent/service/deregister/服务id

4.启动服务node_exporter :

./node_exporter --web.listen-address&#61;":9500"

5.查看注册成功 &#xff1a;http://192.168.253.215:8500/ui/dc1/services/test1/instances

6.查看peometheus是否正常 http://192.168.253.215:9090/targets

7.查看grafana&#xff0c;多了一条曲线


六.alertmanager


七.Grafana嵌入到自己的项目


八.Grafana API报告的导出为PDF

由于Grafana插件不支持docker&#xff0c;需要自己安装grafana程序

 

wget https://dl.grafana.com/oss/release/grafana-7.3.5-1.x86_64.rpm
sudo yum install grafana-7.3.5-1.x86_64.rpm
service grafana-server startyum install -y libXcomposite libXdamage libXtst cups libXScrnSaver pango atk adwaita-cursor-theme adwaita-icon-theme at at-spi2-atk at-spi2-core cairo-gobject colord-libs dconf desktop-file-utils ed emacs-filesystem gdk-pixbuf2 glib-networking gnutls gsettings-desktop-schemas gtk-update-icon-cache gtk3 hicolor-icon-theme jasper-libs json-glib libappindicator-gtk3 libdbusmenu libdbusmenu-gtk3 libepoxy liberation-fonts liberation-narrow-fonts liberation-sans-fonts liberation-serif-fonts libgusb libindicator-gtk3 libmodman libproxy libsoup libwayland-cursor libwayland-egl libxkbcommon m4 mailx nettle patch psmisc redhat-lsb-core redhat-lsb-submod-security rest spax time trousers xdg-utils xkeyboard-config

 

安装插件和grafana-reporter

grafana-cli plugins install grafana-image-renderer安装一下库&#xff0c;不然grafana-reporter会报错
yum install texlive

在第七步的基础上配置Grafana

手动下载pdf&#xff0c;grafana的看板是中文时会有问题&#xff0c;但指标是中文&#xff0c;没问题


九.prometheus API的使用

获取到所有job
http://192.168.253.215:9090/api/v1/label/job/values查询10秒内数据
http://192.168.253.215:9090/api/v1/query_range?query&#61;network_traffic_input&start&#61;1607999428.447&end&#61;1607999468.447&step&#61;10s查询指标
http://192.168.253.215:9090/api/v1/series?match[]&#61;up{job&#61;\"network_traffic\"}&match[]&#61;network_traffic_input{adapter_name&#61;\"ens33\"}查询当前
http://192.168.253.215:9090/api/v1/query?query&#61;network_traffic_input查询
http://192.168.253.215:9090/api/v1/query_range?query&#61;locust_stats_avg_content_length{instance&#61;"some_instance1"} offset 15m&start&#61;1608009390&end&#61;1608012990&step&#61;15
编码后&#xff1a;
http://192.168.253.215:9090/api/v1/query_range?query&#61;locust_stats_avg_content_length%7Binstance%3D%22some_instance1%22%7D%20offset%2015m&start&#61;1608009390&end&#61;1608012990&step&#61;15consul注册服务
curl -X PUT -d &#39;{"id": "test1","name": "test1","address": "192.24.17.156","port": 9500,"tags": ["dev"],"checks": [{"http": "http://192.24.17.156:9500/","interval": "5s"}]}&#39;     http://192.24.17.156:8500/v1/agent/service/registergrafana下载包&#xff1a;https://grafana.com/grafana/download?platform&#61;linux
./grafana-server -config&#61;/home/ops/grafana-7.3.5/conf/grafana.ini cfg:default.paths.plugins&#61;/home/ops/grafana-7.3.5/plugins

参考文章&#xff1a;

1.locust &#43; Prometheus &#43; grafana https://bugvanisher.cn/2020/04/05/locust-with-prometheus-and-grafana/

2.pushgateway安装使用&#xff1a; https://www.cnblogs.com/xiaobaozi-95/p/10684524.html

3.prometheus file_sd_config配置项 https://www.cnblogs.com/faberbeta/p/13597816.html

4.prometheus consul&#xff1a;https://blog.51cto.com/1000682/2363038

5.alertmanager&#xff1a;https://www.cnblogs.com/xiaobaozi-95/p/10740511.html

6.动态更新prometheus 报警规则 https://www.lijiaocn.com/%E6%8A%80%E5%B7%A7/2018/08/30/confd-prometheus-dynamic-config.html

7.Grafana嵌入到自己的项目&#xff1a;https://blog.csdn.net/weixin_44534391/article/details/107019567?utm_medium&#61;distribute.pc_relevant.none-task-blog-baidulandingword-3&spm&#61;1001.2101.3001.4242

8.Grafana导出pdf &#xff1a;https://blog.csdn.net/shen12138/article/details/110199638

9.pushgateway python 使用https://www.cnblogs.com/xiao987334176/p/9933963.html


推荐阅读
  • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
  • 本文介绍了如何利用npm脚本和concurrently工具,实现本地开发环境中多个监听服务的同时启动,包括HTTP服务、自动刷新、Sass和ES6支持。 ... [详细]
  • 本文详细介绍如何在VSCode中配置自定义代码片段,使其具备与IDEA相似的代码生成快捷键功能。通过具体的Java和HTML代码片段示例,展示配置步骤及效果。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • 本文详细介绍如何使用arm-eabi-gdb调试Android平台上的C/C++程序。通过具体步骤和实用技巧,帮助开发者更高效地进行调试工作。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • MySQL 用户创建失败的解决方案
    本文详细介绍了在 MySQL 中遇到用户创建失败问题时的解决方法,包括如何正确配置环境、执行命令以及常见错误排查技巧。通过逐步指导,帮助用户顺利添加和管理 MySQL 用户。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 在网页开发中,页面加载速度是一个关键的用户体验因素。为了提升加载效率,避免在PageLoad事件中进行大量数据绑定操作,可以采用异步加载和特定控件来优化页面加载过程。 ... [详细]
  • 选择适合生产环境的Docker存储驱动
    本文旨在探讨如何在生产环境中选择合适的Docker存储驱动,并详细介绍不同Linux发行版下的配置方法。通过参考官方文档和兼容性矩阵,提供实用的操作指南。 ... [详细]
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • Coursera ML 机器学习
    2019独角兽企业重金招聘Python工程师标准线性回归算法计算过程CostFunction梯度下降算法多变量回归![选择特征](https:static.oschina.n ... [详细]
author-avatar
_陈灵宝互粉号2
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有