SpringCloud整合Prometheus出现问题解决

环境:
SpringBoot 2.2.5.RELEASE,SpringCloud Hoxton.SR5

依赖:

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>io.micrometer</groupId>
            <artifactId>micrometer-core</artifactId>
        </dependency>
        <dependency>
            <groupId>io.micrometer</groupId>
            <artifactId>micrometer-registry-prometheus</artifactId>
        </dependency>

启动类中添加以下bean

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

yml文件配置:

# prometheus相关
management:
  endpoints:
    web:
      exposure:
        include:  '*'
      #注意此处使用,访问的时候必须访问/actuator/prometheus,如不配置则访问/prometheus
      base-path: /actuator

  metrics:
    tags:
      application: ${spring.application.name}

问题一:添加了依赖以后,无论是访问swagger还是 /actuator/prometheus会出现login,这是因为security的原因
解决办法:

@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(securedEnabled = true, prePostEnabled = true)// 控制@Secured权限注解
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        /**
         * 所有都能訪問,放棄判斷權限
         */
        http.requestMatcher(EndpointRequest.toAnyEndpoint())
                .authorizeRequests((requests) -> requests.anyRequest().permitAll());

    }
}

问题二 出现 HttpMessageNotWritableException: No converter for [class java.lang.String]

解决办法很简单:

事情的原因是由于其他同事由于要解决long、bigint转json丢失精度
在WebMvcConfig中直接new MappingJackson2HttpMessageConverter对象,而它只支持MediaType.APPLICATION_JSON一种类型。

解决办法:
将丢失的mediaTypes类型都加进来。

@Configuration
class WebMvcConfig extends WebMvcConfigurationSupport {
    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        StringHttpMessageConverter converter = new StringHttpMessageConverter();
        converter.setSupportedMediaTypes(Arrays.asList(MediaType.TEXT_PLAIN));
        converters.add(converter);
	}
}

SpringBoot集成prometheus
springBoot或者springCloud 的集成 Prometheus监控-数据无法解析
如何解决这种情况下的Could not find acceptable representation
通过micrometer实时监控线程池的各项指标

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一个用于构建分布式系统的开发工具包,而Prometheus是一个开源的监控和警报系统。它们可以结合使用,以实现对Spring Cloud应用程序的监控和指标收集。 在Spring Cloud中,你可以使用Spring Boot Actuator模块来暴露应用程序的运行时指标。这些指标包括HTTP请求的计数、错误率、内存使用情况等。Prometheus可以通过轮询这些指标的端点来收集数据,并将其存储在自己的时间序列数据库中。 要将Spring Cloud与Prometheus集成,你需要做以下几个步骤: 1. 添加Prometheus依赖:在你的Spring Boot项目中,添加Prometheus相关的依赖,如`micrometer-registry-prometheus`。 2. 配置Prometheus端点:在`application.properties`或`application.yml`文件中,配置Spring Boot Actuator的端点路径和Prometheus的路径。 3. 启用Prometheus收集器:通过添加`@EnablePrometheusEndpoint`注解,启用Prometheus收集器。 4. 配置Prometheus收集器:通过添加`@EnableSpringBootMetricsCollector`注解,配置Prometheus收集器的行为。 5. 启动Prometheus服务器:在你的环境中启动Prometheus服务器,并配置它来定期抓取Spring Cloud应用程序的指标。 一旦配置完成,Prometheus就可以定期从你的Spring Cloud应用程序中收集指标,并将其存储在自己的数据库中。你可以使用Prometheus的查询语言(PromQL)来查询和分析这些指标,并创建自定义的监控仪表盘和警报规则。 希望这些信息能对你有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值