本文将详细介绍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=DOWNERROR="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 图形化监控实践相关推荐

  1. 技术实践丨Prometheus+Grafana搭建HBase监控仪表盘

    摘要:Grafana+Prometheus是目前非常流行的监控方案,图形化展示非常强大. 本文分享自华为云社区<Prometheus+Grafana搭建HBase监控仪表盘>,原文作者:L ...

  2. 使用PMM图形化监控MySQL MGR动态

    * GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 1.引入 2.PMM监控的安装和配置使用 2.1PMM介绍 2.2PMM安装方式 3.通过web页面添加MGR组复制监 ...

  3. grafana图形化数据展示软件介绍

    grafana图形化数据展示软件介绍 http://grafana.org/ 一.从官网上看一下特色 Rich Graphing Fast and flexible client side graph ...

  4. 使用snmp对DNS服务器进行图形化监控

    通常情况下如果需要了解DNS服务器的工作状态往往需要telnet或ssh到服务器上以命令的方式来获取.该方式不但麻烦而且不直观.本文介绍一种通过SNMP来对DNS服务器进行图形化监控的方法. 该系统主 ...

  5. Shell图形化监控网络流量

    shell图形化监控网络流量 网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还 ...

  6. 基于linux网络流量监控与分析软件的设计与实现shell,Shell图形化监控网络流量

    网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还有Nagios这样的监控主机状 ...

  7. 【转载】Shell图形化监控网络流量

    网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还有Nagios这样的监控主机状 ...

  8. shell图形化监控网络流量 网络流量的监控工具有很多,如:Mrtg、Cacti、Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求。除了网络流量监控工具以外,还

    网络流量的监控工具有很多,如:Mrtg.Cacti.Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求.除了网络流量监控工具以外,还有Nagios这样的监控主机状 ...

  9. 基于 Prometheus 的边缘计算监控实践

    监控作为边缘计算基础设施的重要组成部分,是边缘稳定性的基本保障.本文主要介绍火山引擎边缘计算的监控实践,分享火山引擎如何进行监控技术选型以及构建监控服务体系.主要内容如下: 边缘计算监控初衷 基于 P ...

最新文章

  1. 怎么才能更好的掌握Python这门语言?该怎么学呢?
  2. 里工实业:用宜搭自主搭建MES系统,实现生产全流程管理
  3. Python的构造函数和析构函数,对象和类的不一样
  4. 5G高频段频谱规划启动 大国博弈加剧
  5. 服务器字体指定 iconfont 字体的下载与使用 200303
  6. GoldenGate中使用FILTER,COMPUTE 和SQLEXEC命令
  7. git快速入门 push/clone/reset/merge/切换分支全都有
  8. socket通信需要网线连接吗_socket方式实现网络通信
  9. python drop用法_python进行数据清理之pandas中的drop用法
  10. 【亚伦博客】《蝙蝠侠前传2:黑暗骑士》里发生了什么
  11. A Busiest Computing Nodes(线段树+优先队列)
  12. Go微服务架构实战 中篇:6. 微服务治理策略
  13. java生气_Java来抢饭碗,C++可别生气
  14. 网易有数永久免费开放BI能力 普惠让技术更有温度
  15. 识别图片中的数字------基本思路
  16. MATLAB Simulink开发ROS无人车与机器人应用 详细教程
  17. Java基础题36:(多选题)下列有关于变量的命名正确的是 A.可以由字母、数字、下划线、”$”组成; 头
  18. 我的世界1.12.2java下载_我的世界:Minecraft Java版 1.12.2-pre1发布
  19. vue 长按复制文字 并弹出复制成功
  20. python爬虫--小猪短租的租房信息

热门文章

  1. Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器...
  2. nmn成分是什么,吃nmn对身体有哪些好处,掌握知识点
  3. java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.gaobo.e5community/com.g
  4. Python数据分析案例07——二手车估价(机器学习全流程,数据清洗、特征工程、模型选择、交叉验证、网格搜参、预测储存)
  5. ibus五笔造词、删词功能
  6. BZOJ4379 : [POI2015]Modernizacja autostrady
  7. Docker Hub的使用以及配置阿里云镜像加速
  8. 【问题】2.Bind for 0.0.0.0:8887 failed: port is already allocated错误
  9. 带例子的测试用例模板
  10. 【Scala】Scala的偏函数和偏应用函数