prometheus监控springboot应用简单使用介绍详解

 更新时间:2019年05月01日 15:26:41   作者:braveheart_07d6  
这篇文章主要介绍了prometheus监控springboot应用简单使用介绍详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

对于springboot应用,需要以下几个步骤

springboot应用开启endpoint,添加actuator的以来和promethus的依赖

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

<dependency>
 <groupId>io.micrometer</groupId>
 <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

在yml文件或者properties文件中,加入以下配置:

management:
 endpoints:
  jmx:
   exposure:
    include: "*"
  web:
   exposure:
    include: "*"
 metrics:
  export:
   datadog:
    application-key: ${spring.application.name}

这里需要注意是,*号是需要加双引号的。

以上两个步骤完毕后,剩下的就是要加registry了:

@Bean MeterRegistryCustomizer<MeterRegistry> configurer(
  @Value("${spring.application.name}") String applicationName) {
  return (registry) -> registry.
    config().
    commonTags("application", applicationName);
}

对于springboot的应用,到此基本完成了。接下来是启动promethus。

配置prometheus

首先要下在prometheus":Prometheus - Monitoring system & time series database"

在下载页面,选择何时的版本下载,推荐下载tar.gz包。下载好后,进行解压。在合适的路径下即可。

这里介绍下prometheus的目录和文件:

1、prometheus采用的都是yml文件的配置方式。
2、在根目录下,有个prometheus.yml配置文件,文件初始化的内容如下:

global:
 scrape_interval:   15s  # 这个是每次数据手机的频率
 evaluation_interval: 15s  # 评估告警规则的频率。

rule_files:
 # - "first.rules"
 # - "second.rules"

scrape_configs:        # 通过这里的配置控制prometheus监控的资源
 - job_name: prometheus   # prometheus自身默认的
  static_configs:
   - targets: ['localhost:9090'] # 默认暴露的是9090端口服务

global是全局配置。具体见上面的注释说明。

3、添加我们的应用,对springboot进行监控

- job_name: 'spring-sample'
  metrics_path: 'actuator/prometheus'  # 这里我们springboot暴露出来的endpoint
  scrape_interval: 5s          # 信息收集时间是间隔5秒
  static_configs:
  - targets: ['localhost:8778']     # 这里是springboot暴露出来的地址和端口

4、这些配置完成后,可以启动prometheus,./prometheus --config.file=prometheus.yml,服务即可启动。具体访问产检官网。

配置grafana

下载grafana,直接启动即可。

1、启动命令参见官网:./grafana-server web

2、配置datasource,选择prometheus。这个里面有个很重要的注意点,我看网上很多人在转如何用prometheus监控springboot应用,估计自己没去实际搭建,在interval这个时间上,默认是数字,比如15,代表是15秒。在添加dashboard的时候,会发现监控图标左上角是个红点,报错:Invalid interval string, expecting a number followed by one of "Mwdhmsy" ,这个错的解决方案就是在这些时间间隔后面加个"s"。问题解决。

3、选择dashboard,import的里输入一个模板,可以去dashboards去找你对应的模板,我们这里选用jvm的4701模板,然后就能看到你的springboot的监控信息了。到此,整个搭建完成。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Spring Boot 集成Mybatis实现主从(多数据源)分离方案示例

    Spring Boot 集成Mybatis实现主从(多数据源)分离方案示例

    本篇文章主要介绍了Spring Boot 集成Mybatis实现主从(多数据源)分离方案实例,具有一定的参考价值,有兴趣的可以了解一下。
    2017-03-03
  • Mybatis-Plus多种批量插入方案对比小结

    Mybatis-Plus多种批量插入方案对比小结

    在项目中优化Mybatis-Plus批量插入性能是关键,通过比较不同方案,本文就来介绍一下Mybatis-Plus多种批量插入方案对比小结,感兴趣都的可以了解一下
    2024-10-10
  • java 两阶段终止线程的正确做法

    java 两阶段终止线程的正确做法

    这篇文章主要给大家分享了java 两阶段终止线程的正确做法,文章列举出错误的做法与正确做法做对比,具有一定的参考价值,需要的小伙伴可以参考一下,希望对你有所帮助
    2021-12-12
  • JAVA多线程并发下的单例模式应用

    JAVA多线程并发下的单例模式应用

    单例模式应该是设计模式中比较简单的一个,也是非常常见的,但是在多线程并发的环境下使用却是不那么简单了,今天给大家分享一个我在开发过程中遇到的单例模式的应用。
    2017-03-03
  • Spring Boot自定义配置属性源(PropertySource)

    Spring Boot自定义配置属性源(PropertySource)

    这篇文章主要介绍了Spring Boot自定义配置属性源(PropertySource),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 利用Java多线程技术导入数据到Elasticsearch的方法步骤

    利用Java多线程技术导入数据到Elasticsearch的方法步骤

    这篇文章主要介绍了利用Java多线程技术导入数据到Elasticsearch的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • java实现选课系统

    java实现选课系统

    这篇文章主要为大家详细介绍了java实现选课系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • SpringBoot JWT实现token登录刷新功能

    SpringBoot JWT实现token登录刷新功能

    JWT本身是无状态的,这点有别于传统的session,不在服务端存储凭证。这种特性使其在分布式场景,更便于扩展使用。接下来通过本文给大家分享SpringBoot JWT实现token登录刷新功能,感兴趣的朋友一起看看吧
    2021-09-09
  • Java日志框架打印应用程序日志代码的执行情况分析

    Java日志框架打印应用程序日志代码的执行情况分析

    在配置INFO日志级别时,日志器(logger)中debug级的日志代码仍会被执行,只是是否输出取决于配置的日志级别,本文基于Java 1.8、SLF4J 1.7.25和Log4j 2.20.0进行实验,详述了日志框架处理日志代码的机制,感兴趣的朋友一起看看吧
    2024-10-10
  • 带你了解Spring AOP的使用详解

    带你了解Spring AOP的使用详解

    这篇文章主要介绍了Spring AOP的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-07-07

最新评论