时间:2021-05-20
1.简介
最近越发觉得,任何一个系统上线,运维监控都太重要了。本文介绍Prometheus + Grafana的方法监控Springboot 2.X,实现美观漂亮的数据可视化。
2.添加监控
Spring-boot-actuator module 可帮助您在将应用程序投入生产时监视和管理应用程序。您可以选择使用 HTTP 端点或 JMX 来管理和监控您的应用程序。Auditing, health, and metrics gathering 也可以自动应用于您的应用程序。引入依赖如下:
<!--监控报警--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><dependency><groupId>io.micrometer</groupId><artifactId>micrometer-registry-prometheus</artifactId></dependency>对于Springboot,要开启Actuator,并打开对应的Endpoint:
#prometheus配置info:alen:alenmanagement:endpoints:web:base-path:/actuatorexposure:include:"*"启动Springboot后,可以通过下面URL看能不能正确获取到监控数据:localhost/actuator/prometheus 获取数据成功,说明Springboot能正常提供监控数据。
主要的端点
3.配置Prometheus
Prometheus 是 Cloud Native Computing Foundation 项目之一,是一个系统和服务监控系统。它按给定的时间间隔从配置的目标收集指标,评估规则表达式,显示结果,并且如果观察到某些条件为真,则可触发警报。
特性
• 多维度 数据模型(由度量名称和键/值维度集定义的时间序列)
• 灵活的查询语言 来利用这种维度
• 不依赖分布式存储;单个服务器节点是自治的
• 时间序列采集通过HTTP上的 pull model 发生
• 推送时间序列 通过中间网关得到支持
• 通过 服务发现 或 静态配置 来发现目标
• 多种模式的 图形和仪表盘支持
• 支持分级和水平 federation
通过 Prometheus 来抓取数据 Prometheus 会按照配置的时间周期去 pull 暴露的端点(/actuator/prometheus)中的指标数据 prometheus.yml 配置
- job_name: 'actuator-ruoyi' # metrics_path defaults to '/metrics' # scheme defaults to 'http'. metrics_path: '/actuator/prometheus' static_configs: - targets: ['10.42.95.4']重然后再启动prometheus,访问prometheus网址,查看targets启动是否正常如下图
4.Grafana添加监控模版
默认启动后Grafana地址为:http://localhost:3000/,登录用户名和密码是admin/admin,import配置grafana id = 4701
最终的效果是这样子的,如下图
5.备注
问题:添加上访问不了Endpoint?解决方案:原因是项目用的shiro,需要添加过滤
filterChainDefinitionMap.put("/actuator/**","anon");问题二:
/O exception (java.io.IOException) caught when processing request to {}->unix://localhost:80: Broken pipe
解决方法:导致这个错误的原因是 project.artifactId 可能包含了大写。改成小写就行
到此这篇关于Springboot添加jvm监控实现数据可视化的文章就介绍到这了,更多相关Springboot jvm监控数据可视化内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们可以试用可视化包——Pyechart。Echarts是百度开源的一个数据可视化JS库,主要用于数据可视化。pyecharts是一个用于生成Echarts图标
基于Web的数据可视化概述。所谓基于Web的数据可视化技术,就是要在Web页面上实现动态数据图表,重点解决以下3个问题:一是获取动态的数据;二是传递数据信息;三
本章目标整合Mybatis,并集成Druid数据源可视化监控Druid数据源使用JPA生成数据表利用注解实现数据库的事物利用注解动态配置数据源全局异常捕获校验请
前言inMap是一款基于canvas的大数据可视化库,专注于大数据方向点线面的可视化效果展示。目前支持散点、围栏、热力、网格、聚合等方式;致力于让大数据可视化变
本文介绍了ANGULAR2与D3.js集成实现自定义可视化的方法,分享给大家,具体如下:目标展现层与逻辑层分离数据与可视化组件相分离数据与视图双向绑定,实时更新