Prometheus + Grafana 图形化监控实践
本文将详细介绍Prometheus和Grafana的快速搭建,并实现JVM、Mysql等实时监控。
本文将在Windows环境搭建Demo。
版权说明: 本文由博主keep丶原创,转载请注明出处。
原文地址:https://blog.csdn.net/qq_38688267/article/details/108101708
文章目录
- 资源下载
- Prometheus-2.20 下载
- Grafana-7.1下载
- 安装启动
- Grafana安装启动
- Prometheus安装启动
- 监控SpringBoot项目JVM
- 1、引入依赖
- 2、增加配置
- 3、Prometheus配置并重启
- 4、检查是否生效
- 5、配置Grafana可视化
- 6、大功告成
- 监控MySQL
- 补充
- Grafana可视化模板
资源下载
Prometheus-2.20 下载
- 官网:https://prometheus.io/
- windows版:https://download.csdn.net/download/qq_38688267/12683264
- Linux版:https://download.csdn.net/download/qq_38688267/12728855
Grafana-7.1下载
- 官网:https://grafana.com/
- windows版:https://download.csdn.net/download/qq_38688267/12683258
- Linux版:https://download.csdn.net/download/qq_38688267/12728849
安装启动
Grafana安装启动
Windows:
Windows版安装启动很简单,下载完成双击安装即可,安装完成后会生成后台服务。Linux:
1、解压:tar -xvzf grafana-7.1.3.linux-amd64.tar.gz
2、运行:/grafana-7.1.3/bin/grafana-server
默认端口:
3000
访问地址:localhost:3000
默认管理员账号密码:admin / admin
Prometheus安装启动
官方文档:https://prometheus.io/docs/introduction/overview/
Windows:
下载完成后解压,根目录下双击运行prometheus.exe
即可Linux:
1、解压:tar -xvzf grafana-7.1.3.linux-amd64.tar.gz
2、运行:/grafana-7.1.3/bin/grafana-server
默认端口:
9090
访问地址:localhost:9090
监控SpringBoot项目JVM
实现JVM监控非常简单。5步即可:
1、引入依赖
增加MAVEN依赖:
<!-- actuator健康监控依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId><version>2.3.3.RELEASE</version></dependency><!-- JVM信息收集 --><dependency><groupId>io.github.mweirauch</groupId><artifactId>micrometer-jvm-extras</artifactId><version>0.2.0</version></dependency>
2、增加配置
在项目application.yml/application.properties中增加配置如下:
management:endpoints:web:exposure:# 监控所有信息,也可以根据需要选择include: "*"# 访问监控父路径,默认"/actuator",base-path: /actuator
3、Prometheus配置并重启
修改Prometheus根目录下的prometheus.yml文件如下:
# my global config
global:scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.# scrape_timeout is set to the global default (10s).
# Alertmanager configuration
alerting:alertmanagers:- static_configs:- targets:# - alertmanager:9093# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:# - "first_rules.yml"# - "second_rules.yml"# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:# The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.- job_name: 'prometheus'# metrics_path defaults to '/metrics'# scheme defaults to 'http'.static_configs:- targets: ['localhost:9090']
########## 以上为默认配置########## 只需要增加下面的配置即可
########## 注意缩进和空格,如果修改配置文件后启动秒退,表示配置文件有问题!# 任务名称- job_name: 'sys-service'# 注意这个指标路径,不要填错了metrics_path: '/actuator/prometheus'static_configs:# 数据对象地址,就我们的JAVA应用地址- targets: ['localhost:8080']
### ======修改完配置后记得重启哦~======= ###
4、检查是否生效
- 检查应用健康监控是否生效
访问 localhost:8080/actuator,查看是否正确返回数据。
如果应用有设置访问拦截之类的,记得要将/actuator/**
设置为白名单哦。
- 检查Prometheus监控是否生效
修改prometheus配置并重启完成后,进入普罗米修斯界面选择status
=>targets
,就可以看到他监控的对象,如果对象中出现了我们之前配置好的对象并且state=UP
表示监控成功。
如果这里我们配置的对象
state=DOWN
且ERROR="INVALID" is not a valid start token
的错误,这个错误是由于监控的数据格式不是Prometheus要求的,需要检查Prometheus的配置:- job_name下的metrice_path
属性是否正确,因为他默认值为/metrics
,但如果是用Actuator组件的话需要配置的路径为/actuator/prometheus
。
5、配置Grafana可视化
- 添加数据源
如果之前没有添加过数据源的话,在进入grafana后就会显示添加数据源的按钮。
如果已经添加过数据源则按下图添加我们之前配置的Prometheus的数据源。
- 增加图表
我们选择比较流行的可视化界面模板,如下图所示操作即可。
此处的4701
在后文的补充中有说明。
等待几秒就会出现如下图所示的表单,输入完信息后,点击Import
即可。
6、大功告成
炫酷的暗黑风格可视化图表就完成了~
还能利用Grafana的告警功能设置监控告警哦~
监控MySQL
TODO。。。
补充
Grafana可视化模板
为了减少不必要的工作,Grafana提供可视化配置模板导入的功能,也维护了官方模块库。
传送门:https://grafana.com/grafana/dashboards
我们在导入时,只需要输入模板的唯一ID即可,ID在详情页中有显示,根据详情页地址也能看出来。
同理,在主页我们根据浏览器的跳转路径提示也可以知道模板的ID。
Prometheus + Grafana 图形化监控实践相关推荐
- 技术实践丨Prometheus+Grafana搭建HBase监控仪表盘
摘要:Grafana+Prometheus是目前非常流行的监控方案,图形化展示非常强大. 本文分享自华为云社区<Prometheus+Grafana搭建HBase监控仪表盘>,原文作者:L ...
- 使用PMM图形化监控MySQL MGR动态
* GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 1.引入 2.PMM监控的安装和配置使用 2.1PMM介绍 2.2PMM安装方式 3.通过web页面添加MGR组复制监 ...
- grafana图形化数据展示软件介绍
grafana图形化数据展示软件介绍 http://grafana.org/ 一.从官网上看一下特色 Rich Graphing Fast and flexible client side graph ...
- 使用snmp对DNS服务器进行图形化监控
通常情况下如果需要了解DNS服务器的工作状态往往需要telnet或ssh到服务器上以命令的方式来获取.该方式不但麻烦而且不直观.本文介绍一种通过SNMP来对DNS服务器进行图形化监控的方法. 该系统主 ...
- Shell图形化监控网络流量
shell图形化监控网络流量 网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还 ...
- 基于linux网络流量监控与分析软件的设计与实现shell,Shell图形化监控网络流量
网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还有Nagios这样的监控主机状 ...
- 【转载】Shell图形化监控网络流量
网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还有Nagios这样的监控主机状 ...
- shell图形化监控网络流量 网络流量的监控工具有很多,如:Mrtg、Cacti、Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求。除了网络流量监控工具以外,还
网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还有Nagios这样的监控主机状 ...
- 基于 Prometheus 的边缘计算监控实践
监控作为边缘计算基础设施的重要组成部分,是边缘稳定性的基本保障.本文主要介绍火山引擎边缘计算的监控实践,分享火山引擎如何进行监控技术选型以及构建监控服务体系.主要内容如下: 边缘计算监控初衷 基于 P ...
最新文章
- 怎么才能更好的掌握Python这门语言?该怎么学呢?
- 里工实业:用宜搭自主搭建MES系统,实现生产全流程管理
- Python的构造函数和析构函数,对象和类的不一样
- 5G高频段频谱规划启动 大国博弈加剧
- 服务器字体指定 iconfont 字体的下载与使用 200303
- GoldenGate中使用FILTER,COMPUTE 和SQLEXEC命令
- git快速入门 push/clone/reset/merge/切换分支全都有
- socket通信需要网线连接吗_socket方式实现网络通信
- python drop用法_python进行数据清理之pandas中的drop用法
- 【亚伦博客】《蝙蝠侠前传2:黑暗骑士》里发生了什么
- A Busiest Computing Nodes(线段树+优先队列)
- Go微服务架构实战 中篇:6. 微服务治理策略
- java生气_Java来抢饭碗,C++可别生气
- 网易有数永久免费开放BI能力 普惠让技术更有温度
- 识别图片中的数字------基本思路
- MATLAB Simulink开发ROS无人车与机器人应用 详细教程
- Java基础题36:(多选题)下列有关于变量的命名正确的是 A.可以由字母、数字、下划线、”$”组成; 头
- 我的世界1.12.2java下载_我的世界:Minecraft Java版 1.12.2-pre1发布
- vue 长按复制文字 并弹出复制成功
- python爬虫--小猪短租的租房信息
热门文章
- Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器...
- nmn成分是什么,吃nmn对身体有哪些好处,掌握知识点
- java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.gaobo.e5community/com.g
- Python数据分析案例07——二手车估价(机器学习全流程,数据清洗、特征工程、模型选择、交叉验证、网格搜参、预测储存)
- ibus五笔造词、删词功能
- BZOJ4379 : [POI2015]Modernizacja autostrady
- Docker Hub的使用以及配置阿里云镜像加速
- 【问题】2.Bind for 0.0.0.0:8887 failed: port is already allocated错误
- 带例子的测试用例模板
- 【Scala】Scala的偏函数和偏应用函数