Grafana可视化监控系统结合SpringBoot使用


Posted in Redis onApril 19, 2022

当面对一个复杂的系统时,我们往往需要监控工具来帮助我们解决一些性能问题。比如之前我们使用SpringBoot Admin来监控应用,从而获取到SpringBoot Actuator暴露的指标信息。今天给大家介绍一个功能强大的监控工具Grafana,只要需要用到监控的地方,用它做可视化就对了!

Grafana简介

Grafana是一款开源的数据可视化和分析工具,不管你的指标信息存储在哪里,你都可以用它来可视化这些数据。同时它还具有告警功能,当指标超出指定范围时会提醒你。

Prometheus简介

Prometheus是一款时序数据库,可以简单理解为带时间的MySQL数据库。由于Grafana只能将数据转换成可视化图表,并没有存储功能,所以我们需要结合Prometheus这类时序数据库一起使用。

安装

使用Docker安装Grafana和Prometheus无疑是最简单的,我们接下来将采用此种方式。

  • 首先下载Grafana的Docker镜像;

docker pull grafana/grafana
  • 下载完成后运行Grafana;

docker run -p 3000:3000 --name grafana \
-d grafana/grafana
  • 接下来下载Prometheus的Docker镜像;

docker pull prom/prometheus
  • /mydata/prometheus/目录下创建Prometheus的配置文件prometheus.yml

global:
  scrape_interval: 5s
  • 运行Prometheus,把宿主机中的配置文件prometheus.yml挂载到容器中去;

docker run -p 9090:9090 --name prometheus \
-v /mydata/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml \
-d prom/prometheus
  • 至此安装完成,是不是很简单!可以通过如下地址访问Grafana,登录账号密码为admin:admin,访问地址:http://192.168.5.78:3000/

Grafana可视化监控系统结合SpringBoot使用

  • 登录Grafana后显示界面如下;

Grafana可视化监控系统结合SpringBoot使用

  • 其实Prometheus也是有可视化界面的,就是有点简陋,访问地址:http://192.168.5.78:9090/

Grafana可视化监控系统结合SpringBoot使用

使用

Grafana已经安装完后,是时候来波实践了,接下来我们来介绍下使用Grafana来监控Linux系统和SpringBoot应用。

监控系统信息

使用node_explorer可以暴露Linux系统的指标信息,然后Prometheus就可以通过定时扫描的方式获取并存储指标信息了。

  • 下载node_explorer的安装包,下载地址:https://prometheus.io/download/#node_exporter

Grafana可视化监控系统结合SpringBoot使用

  • 这次我们直接把node_explorer安装到Linux服务器上(如果使用Docker容器安装,监控的会是Docker容器的指标信息),将下载的安装包解压到指定目录,并修改文件夹名称:

cd /mydata
tar -zxvf node_exporter-1.1.2.linux-amd64.tar.gz
mv node_exporter-1.1.2.linux-amd64 node_exporter
  • 进入解压目录,使用如下命令运行node_explorer,服务将运行在9100端口上;

cd node_exporter
./node_exporter >log.file 2>&1 &
  • 使用curl命令访问获取指标信息接口,获取到信息表示运行成功;

curl http://localhost:9100/metrics
# HELP promhttp_metric_handler_requests_in_flight Current number of scrapes being served.
# TYPE promhttp_metric_handler_requests_in_flight gauge
promhttp_metric_handler_requests_in_flight 1
# HELP promhttp_metric_handler_requests_total Total number of scrapes by HTTP status code.
# TYPE promhttp_metric_handler_requests_total counter
promhttp_metric_handler_requests_total{code="200"} 2175
promhttp_metric_handler_requests_total{code="500"} 0
promhttp_metric_handler_requests_total{code="503"} 0
  • 接下来修改Prometheus的配置文件prometheus.yml,创建一个任务定时扫描node_explorer暴露的指标信息;

scrape_configs:
  - job_name: node
    static_configs:
    - targets: ['192.168.5.78:9100']
  • 重启Prometheus容器,可以通过加号->Dashboard来创建仪表盘;

Grafana可视化监控系统结合SpringBoot使用

  • 当然你还可以选择去Grafana的仪表盘市场下载一个Dashboard,市场地址:https://grafana.com/grafana/dashboards

Grafana可视化监控系统结合SpringBoot使用

  • 这里选择了Node Exporter Full这个仪表盘,记住它的ID,访问地址:https://grafana.com/grafana/dashboards/1860

Grafana可视化监控系统结合SpringBoot使用

  • 选择导入Dashboard并输入ID,最后点击Load即可;

Grafana可视化监控系统结合SpringBoot使用

  • 选择数据源为Prometheus,最后点击Import

Grafana可视化监控系统结合SpringBoot使用

  • 导入成功后就可以在Grafana中看到实时监控信息了,是不是够炫酷!

Grafana可视化监控系统结合SpringBoot使用

监控SpringBoot应用

监控SpringBoot应用需要依靠actuatormicrometer,通过暴露actuator的端点,Prometheus可以定时获取并存储指标信息。

  • 修改项目的pom.xml文件,添加actuatormicrometer依赖;

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <!-- 集成micrometer,将监控数据存储到prometheus -->
    <dependency>
        <groupId>io.micrometer</groupId>
        <artifactId>micrometer-registry-prometheus</artifactId>
    </dependency>
</dependencies>
  • 修改应用配置文件application.yml,通过actuator暴露监控端口/actuator/prometheus

management:
  endpoints:
    web:
      exposure:
        # 暴露端点`/actuator/prometheus`
        include: 'prometheus'
  metrics:
    tags:
      application: ${spring.application.name}
  • 在监控SpringBoot应用之前,我们需要先运行一个SpringBoot应用,使用如下命令运行即可;

docker run -p 8088:8088 --name mall-tiny-grafana \
-v /etc/localtime:/etc/localtime \
-v /mydata/app/mall-tiny-grafana/logs:/var/logs \
-e TZ="Asia/Shanghai" \
-d mall-tiny/mall-tiny-grafana:1.0-SNAPSHOT
  • 修改Prometheus的配置文件prometheus.yml,创建一个任务定时扫描actuator暴露的指标信息,这里需要注意下,由于SpringBoot应用运行在Docker容器中,需要使用docker inspect mall-tiny-grafana |grep IPAddress来获取容器IP地址;

scrape_configs:
  # 采集任务名称
  - job_name: 'mall-tiny-grafana'
    # 采集时间间隔
    scrape_interval: 5s
    # 采集超时时间
    scrape_timeout: 10s
    # 采集数据路径
    metrics_path: '/actuator/prometheus'
    # 采集服务的地址
    static_configs:
      - targets: ['172.17.0.5:8088']
  • 我们可以通过Prometheus的可视化界面,来确定Prometheus是否能获取到指标信息;

Grafana可视化监控系统结合SpringBoot使用

  • 同样,我们可以从仪表盘市场导入仪表盘,访问地址:https://grafana.com/grafana/dashboards/14370

Grafana可视化监控系统结合SpringBoot使用

  • 导入成功后就可以在Grafana中看到SpringBoot实时监控信息了,果然够炫酷!

Grafana可视化监控系统结合SpringBoot使用

总结

通过对Grafana的一波实践,我们可以发现,使用Grafana来进行数据可视化的过程是这样的:首先我们得让被监控方将指标信息暴露出来,然后用Prometheus定时获取并存储指标信息,最后将Prometheus配置为Grafana的可视化数据源。

参考资料

项目源码地址

https://github.com/macrozheng/mall-learning/tree/master/mall-tiny-grafana

到此这篇关于使用Grafana监控Redis的文章就介绍到这了!

Redis 相关文章推荐
Redis 配置文件重要属性的具体使用
May 20 Redis
redis实现排行榜功能
May 24 Redis
Django使用redis配置缓存的方法
Jun 01 Redis
Redis Cluster集群动态扩容的实现
Jul 15 Redis
缓存替换策略及应用(以Redis、InnoDB为例)
Jul 25 Redis
Redis Stream类型的使用详解
Nov 11 Redis
分布式架构Redis中有哪些数据结构及底层实现原理
Mar 13 Redis
一文搞懂Redis中String数据类型
Apr 03 Redis
Redis特殊数据类型bitmap位图
Jun 01 Redis
Redis全局ID生成器的实现
Jun 05 Redis
关于Redis的主从复制及哨兵问题
Jun 16 Redis
Redis官方可视化工具RedisInsight安装使用教程
Redis实现一个账号只能登录一个设备
Apr 19 #Redis
Redis如何实现验证码发送 以及限制每日发送次数
Apr 18 #Redis
Redis实战高并发之扣减库存项目
Redis中key的过期删除策略和内存淘汰机制
解决 Redis 秒杀超卖场景的高并发
redis 解决库存并发问题实现数量控制
You might like
PHP sprintf() 函数的应用(定义和用法)
2012/06/29 PHP
php上传图片存入数据库示例分享
2014/03/11 PHP
神盾加密解密教程(三)PHP 神盾解密工具
2014/06/08 PHP
基于laravel制作APP接口(API)
2016/03/15 PHP
三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
2017/11/13 PHP
javascript web页面刷新的方法收集
2009/07/02 Javascript
javascript开发技术大全 第4章 直接量与字符集
2011/07/03 Javascript
js 验证密码强弱的小例子
2013/03/21 Javascript
JS显示表格内指定行html代码的方法
2015/03/31 Javascript
js实现固定显示区域内自动缩放图片的方法
2015/07/18 Javascript
基于Javascript倒计时效果
2016/12/22 Javascript
vue :src 文件路径错误问题的解决方法
2018/05/15 Javascript
Vue 让元素抖动/摆动起来的实现代码
2018/05/31 Javascript
node中的session的具体使用
2018/09/14 Javascript
微信小程序textarea层级过高(盖住其他元素)问题的解决办法
2019/03/04 Javascript
vue里的data要用return返回的原因浅析
2019/05/28 Javascript
微信小程序上传图片并等比列压缩到指定大小的实例代码
2019/10/24 Javascript
vue实现移动端图片上传功能
2019/12/23 Javascript
阿望教你用vue写扫雷小游戏
2020/01/20 Javascript
详解JSON.stringify()的5个秘密特性
2020/05/26 Javascript
Python爬虫代理IP池实现方法
2017/01/05 Python
Python 转义字符详细介绍
2017/03/21 Python
Bottle框架中的装饰器类和描述符应用详解
2017/10/28 Python
pytorch使用horovod多gpu训练的实现
2020/09/09 Python
Pycharm-community-2020.2.3 社区版安装教程图文详解
2020/12/08 Python
Python操作Excel的学习笔记
2021/02/18 Python
优秀英语专业毕业生求职信
2013/11/23 职场文书
爱情检讨书大全
2014/01/21 职场文书
应届大学生求职信
2014/07/20 职场文书
模范教师材料大全
2014/12/16 职场文书
2015年高三班主任工作总结
2015/05/21 职场文书
网络舆情信息简报
2015/07/21 职场文书
迎国庆主题班会
2015/08/17 职场文书
2016年10月份红领巾广播稿
2015/12/21 职场文书
动视暴雪取消疫苗禁令 让所有员工返回线下工作
2022/04/03 其他游戏
Tomcat执行startup.bat出现闪退的原因及解决办法
2022/04/20 Servers