Spring Cloud填坑日志(3)——Spring Boot Actuator的/pause端点使用

背景

    最近在学习周立大神的《Spring Cloud与Docker微服务架构实战》,在翻阅Eureka的健康检查这一部分的时候,发现有一个小备注:

  • 当eureka.client.healthcheck.enabled=true时,/pause端点(该端点由Spring Boot Actuator提供,用于暂停应用)无法正常工作,经笔者测试,发现当eureka.client.healthcheck.enabled=true时,请求/pause端点也无法将应用在Eureka上的状态标记为DOWN。由于该Bug尚未修复,建议读者留意。

于是我想重现一下这个Bug,但是并不知道如何使用这个端点,于是在网上搜了/pause端点的使用方式:实用技巧:Spring Cloud中,如何优雅下线微服务?,开启了踩坑之旅。

前提

    本人使用的相关软件版本是Spring Boot 1.x + Spring Cloud Edgware。

问题描述

    本人使用以下方法配置和暴露/pause端点:

management:
  endpoint:
    # 启用pause端点
    pause:
      enabled: true
    # 启用restart端点,之所以要启用res
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot Actuator是一组可插拔的管理端点,它提供了有关应用程序运行状况的信息,例如健康状况、内存使用情况、日志记录等。下面是Spring Boot Actuator使用方法和案例。 1. 添加Spring Boot Actuator依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> ``` 2. 配置Spring Boot Actuator 在application.properties文件中添加以下配置: ```properties # 启用所有端点 management.endpoints.web.exposure.include=* # 启用health和info端点 management.endpoints.web.exposure.include=health,info # 配置端点访问路径 management.endpoints.web.base-path=/actuator ``` 3. 访问Spring Boot Actuator端点 启动Spring Boot应用程序后,可以通过以下URL访问Actuator端点: - /actuator/health:应用程序的健康状况。 - /actuator/info:应用程序的信息。 - /actuator/metrics:应用程序的度量指标。 - /actuator/loggers:应用程序的日志记录器。 - /actuator/httptrace:应用程序的HTTP跟踪信息。 - /actuator/env:应用程序的环境变量。 例如,访问/actuator/health端点可以得到应用程序的健康状况: ```json { "status": "UP" } ``` 访问/actuator/metrics端点可以得到应用程序的度量指标: ```json { "counter.status.200.root": 1, "gauge.response.root": 50, "gauge.response.sample": 50 } ``` 访问/actuator/loggers端点可以得到应用程序的日志记录器: ```json { "configuredLevel": "INFO", "effectiveLevel": "INFO", "name": "root" } ``` 访问/actuator/env端点可以得到应用程序的环境变量: ```json { "profiles": [ "default" ], "systemProperties": { "java.runtime.name": "Java(TM) SE Runtime Environment", "user.timezone": "Asia/Shanghai", "java.version": "1.8.0_241", "os.name": "Mac OS X", "user.country": "CN", "user.language": "zh", "java.vm.specification.version": "1.8", "user.home": "/Users/username", "java.awt.headless": "true", "file.separator": "/", "java.specification.vendor": "Oracle Corporation", "java.library.path": "/Users/username/Library/Java/Extensions:/Library/Java/Extensions:/Network/Library/Java/Extensions:/System/Library/Java/Extensions:/usr/lib/java:.", "java.vm.name": "Java HotSpot(TM) 64-Bit Server VM", "user.dir": "/Users/username/workspace/demo", "java.runtime.version": "1.8.0_241-b07", "os.version": "10.15.6", "java.vendor.url": "http://java.oracle.com/", "java.vm.vendor": "Oracle Corporation", "spring.output.ansi.enabled": "ALWAYS", "file.encoding": "UTF-8", "java.vm.specification.vendor": "Oracle Corporation", "java.vendor": "Oracle Corporation", "java.vm.version": "25.241-b07", "line.separator": "\n", "user.name": "username", "java.class.version": "52.0", "java.vendor.url.bug": "http://bugreport.sun.com/bugreport/", "sun.cpu.endian": "little", "sun.io.unicode.encoding": "UnicodeBig", "spring.datasource.password": "******", "spring.datasource.url": "jdbc:mysql://localhost:3306/demo", "spring.datasource.username": "root", "spring.datasource.driver-class-name": "com.mysql.jdbc.Driver", "spring.jpa.database-platform": "org.hibernate.dialect.MySQL5InnoDBDialect", "spring.jpa.hibernate.ddl-auto": "create-drop", "spring.jpa.show-sql": "true", "spring.jpa.properties.hibernate.format_sql": "true" } } ``` 4. 自定义Spring Boot Actuator端点 除了使用默认的Actuator端点外,还可以自定义自己的端点。只需要实现Endpoint接口即可。 例如,以下是一个自定义的端点,它返回当前时间: ```java @Component public class TimeEndpoint implements Endpoint<Long> { @Override public String getId() { return "time"; } @Override public boolean isEnabled() { return true; } @Override public boolean isSensitive() { return false; } @Override public Long invoke() { return System.currentTimeMillis(); } } ``` 启动应用程序后,可以通过访问/actuator/time端点来获取当前时间。 以上就是Spring Boot Actuator使用方法和案例,它可以帮助我们更好地管理和监控Spring Boot应用程序的运行状况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值