Exploring
首页
  • Java

    • 面向对象的思想OOP
    • 浅谈Java反射原理
    • endorsed覆盖JDK中的类
  • 认证与授权

    • LDAP概念和原理介绍
    • OAuth2介绍
  • Impala

    • Impala 介绍
  • MySQL

    • 关于MySQL的一些面试题
    • 解决MySQL不到中文数据
    • 数据库之事务与实现原理
  • Oracle

    • oracle的表空间,用户管理,表操作,函数
    • oracle的查询、视图、索引
    • plsql简单入门
  • Redis

    • 数据类型详解
    • 跳越表
    • 数据持久化的两种方式
  • 共识算法

    • gossip
  • RPC

    • GRPC初识与快速入门
    • ProtocolBuffer基本语法
  • RabbitMQ

    • RabbitMQ入门程序之HelloWorld
    • RabbitMQ之工作模式
  • Zookeeper

    • Zookeeper一文入门
  • Docker

    • Docker入门初体验
  • Maven

    • 把自己的包到Maven中央仓库
    • Maven之自定义插件
  • Nginx

    • nginx的安装
    • nginx的配置文件
    • nignx 的变量
  • Tomcat

    • Servlet3通过SPI进行注册组件
  • Vagrant

    • vagrant 初始化
    • vagrant 常用配置
    • vagrant 自己制作 box
  • Linux

    • 启动方式 Systemd
    • 后台服务
    • 防火墙与 Iptables
  • 设计模式

    • 设计模式-代理
    • 设计模式-单例模式
    • 设计模式-迭代器
  • 分布式

    • CAP 理论
  • 数据结构

    • 数据结构之堆Heap
    • 数据结构之哈希表
    • 数据结构之队列
  • 计算机网络

    • HTTP与HTTPS详解
    • 浅谈DNS协议
    • ISP中的网络层
  • 算法

    • 常用查找算法及Java实现
    • 常用排序算法及Java实现
    • 迪杰斯特拉算法
  • 操作系统

    • 操作系统之进程调度算法
    • 操作系统之进程通讯IPC
    • 操作系统之内存管理
  • 抓包

    • 生成安卓系统证书
  • 加解密

    • 常见加密算法
    • 公开秘钥基础知识
    • RSA 解析
  • Windows

    • scoop 包管理
    • windows-terminal 配置
    • 增强 PowerShell
归档
Github (opens new window)
首页
  • Java

    • 面向对象的思想OOP
    • 浅谈Java反射原理
    • endorsed覆盖JDK中的类
  • 认证与授权

    • LDAP概念和原理介绍
    • OAuth2介绍
  • Impala

    • Impala 介绍
  • MySQL

    • 关于MySQL的一些面试题
    • 解决MySQL不到中文数据
    • 数据库之事务与实现原理
  • Oracle

    • oracle的表空间,用户管理,表操作,函数
    • oracle的查询、视图、索引
    • plsql简单入门
  • Redis

    • 数据类型详解
    • 跳越表
    • 数据持久化的两种方式
  • 共识算法

    • gossip
  • RPC

    • GRPC初识与快速入门
    • ProtocolBuffer基本语法
  • RabbitMQ

    • RabbitMQ入门程序之HelloWorld
    • RabbitMQ之工作模式
  • Zookeeper

    • Zookeeper一文入门
  • Docker

    • Docker入门初体验
  • Maven

    • 把自己的包到Maven中央仓库
    • Maven之自定义插件
  • Nginx

    • nginx的安装
    • nginx的配置文件
    • nignx 的变量
  • Tomcat

    • Servlet3通过SPI进行注册组件
  • Vagrant

    • vagrant 初始化
    • vagrant 常用配置
    • vagrant 自己制作 box
  • Linux

    • 启动方式 Systemd
    • 后台服务
    • 防火墙与 Iptables
  • 设计模式

    • 设计模式-代理
    • 设计模式-单例模式
    • 设计模式-迭代器
  • 分布式

    • CAP 理论
  • 数据结构

    • 数据结构之堆Heap
    • 数据结构之哈希表
    • 数据结构之队列
  • 计算机网络

    • HTTP与HTTPS详解
    • 浅谈DNS协议
    • ISP中的网络层
  • 算法

    • 常用查找算法及Java实现
    • 常用排序算法及Java实现
    • 迪杰斯特拉算法
  • 操作系统

    • 操作系统之进程调度算法
    • 操作系统之进程通讯IPC
    • 操作系统之内存管理
  • 抓包

    • 生成安卓系统证书
  • 加解密

    • 常见加密算法
    • 公开秘钥基础知识
    • RSA 解析
  • Windows

    • scoop 包管理
    • windows-terminal 配置
    • 增强 PowerShell
归档
Github (opens new window)
  • Java

    • 基础

    • 并发与多线程

    • 日志系统

    • 单元测试

    • JVM

    • Spring

    • SpringBoot

      • SpringBoot 监控
        • SpringBoot-Actuator
          • 介绍
          • Endpoints
        • Prometheus
        • Grafana
        • 环境搭建
        • 简单示例
        • 效果预览
    • 一些工具

  • 语言
  • Java
  • SpringBoot
unclezs
2022-07-07
0
目录

SpringBoot 监控

我们一般常用 SpringBoot-Actuator + Prometheus + Grafana 对我们的应用运行情况做监控。

# SpringBoot-Actuator

# 介绍

致动器(actuator)是2018年公布的计算机科学技术名词。

Spring Boot Actuator提供了对SpringBoot应用程序(可以是生产环境)监视和管理的能力, 可以选择通过使用HTTP Endpoint或使用JMX来管理和监控SpringBoot应用程序。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
1
2
3
4

# Endpoints

Spring Boot Actuator 允许你通过Endpoints对Spring Boot进行监控和交互。

Spring Boot 内置的Endpoint包括(两种 Endpoint: WEB和JMX, web方式考虑到安全性默认只开启了/health):

ID JMX Web Endpoint功能描述
auditevents Yes No 暴露当前应用的audit events (依赖AuditEventRepository)
beans Yes No Spring中所有Beans
caches Yes No 暴露可用的缓存
conditions Yes No 展示configuration 和auto-configuration类中解析的condition,并展示是否匹配的信息.
configprops Yes No 展示所有的@ConfigurationProperties
env Yes No 展示环境变量,来源于ConfigurableEnvironment
flyway Yes No flyway数据迁移信息(依赖Flyway)
health Yes Yes 展示应用的健康信息
heapdump N/A No (web应用时)hprof 堆的dump文件(依赖HotSpot JVM)
httptrace Yes No 展示HTTP trace信息, 默认展示前100个(依赖HttpTraceRepository)
info Yes No 应用信息
integrationgraph Yes No 展示spring集成信息(依赖spring-integration-core)
jolokia N/A No (web应用时)通过HTTP暴露JMX beans(依赖jolokia-core)
logfile N/A No (web应用时)如果配置了logging.file.name 或者 logging.file.path,展示logfile内容
loggers Yes No 展示或者配置loggers,比如修改日志的等级
liquibase Yes No Liquibase 数据迁移信息(依赖Liquibase)
metrics Yes No 指标信息
mappings Yes No @RequestMapping映射路径
prometheus N/A No (web应用时)向prometheus暴露监控信息(依赖micrometer-registry-prometheus)
quartz Yes No 展示 quartz任务信息
scheduledtasks Yes No 展示Spring Scheduled 任务信息
sessions Yes No session信息
shutdown Yes No 关闭应用
startup Yes No 展示ApplicationStartup的startup步骤的数据(依赖通在SpringApplication配置BufferingApplicationStartup)
threaddump Yes No 线程dump

当然你也可以自己定义暴露哪些endpoint,

比如JMX时:

management:
  endpoints:
    jmx:
      exposure:
        include: "health,info"
1
2
3
4
5

web时(*代表所有):

management:
  endpoints:
    web:
      exposure:
        include: "*"
        exclude: "env,beans"
1
2
3
4
5
6

# Prometheus

Prometheus 是由前Google 工程师从2012 年开始在 Soundcloud 以开源软件的形式进行研发的系统监控和告警工具包,自此以后,许多公司和组织都采用了 Prometheus 作为监控告警工具。 Prometheus 的开发者和用户社区非常活跃,它现在是一个独立的开源项目,可以独立于任何公司进行维护。

1、多维数据模型:由度量名称和键值对标识的时间序列数据

2、PromSQL:一种灵活的查询语言,可以利用多维数据完成复杂的查询

3、不依赖分布式存储,单个服务器节点可直接工作

4、基于HTTP的pull方式采集时间序列数据

5、推送时间序列数据通过PushGateway组件支持

6、通过服务发现或静态配置发现目标

7、多种图形模式及仪表盘支持(grafana)

8、适用于以机器为中心的监控以及高度动态面向服务架构的监控

# Grafana

Grafana 是一个分析平台,可用于查询和可视化数据,然后根据可视化结果创建和共享仪表板。 Grafana 提供一个Azure 数据资源管理器插件,通过该插件可连接到Azure 数据资源管理器并可视化数据。 本文介绍如何将Azure 数据资源管理器设置为Grafana 的数据源,然后将来自示例群集的数据可视化。

# 环境搭建

参考教程即可

Mac部署Prometheus + Grafana监控 (opens new window)

# 简单示例

samples - springboot-actuator (opens new window)

# 效果预览

我随便加了几个监控指标

image-20220707101537473

在 GitHub 编辑此页 (opens new window)
上次更新: 2024/02/25, 12:11:11
SpringBoot中的服务端推送SSE
用Jcommander打造自己的Java的命令行工具

← SpringBoot中的服务端推送SSE 用Jcommander打造自己的Java的命令行工具→

Theme by Vdoing | Copyright © 2018-2024 unclezs
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式