zoukankan      html  css  js  c++  java
  • Spring Boot 2.x 自定义Endpoint

    概述

    在使用Spring Boot的时候我们经常使用actuator,健康检查,bus中使用/refresh等。这里记录如何使用注解的方式自定义Endpoint。可用于满足一些服务状态监控,或者优雅停机等。

    准备

    Spring Boot项目,pom中加入:

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

    编写自定义Endpoint

    @Configuration
    @Endpoint(id = "my-endpoint")
    public class MyEndpoint {
    
        @ReadOperation
        public Map<String, Object> endpoint() {
            Map<String, Object> map = new HashMap<>(16);
            map.put("message", "this is my endpoint");
            return map;
        }
    }
    

    1.配置

    management.endpoints.web.exposure.include=my-endpoint

    2.启动&测试

    启动后可以看到日志:

    Mapped "{[/actuator/my-endpoint],methods=[GET],produces=[application/vnd.spring-boot.actuator.v2+json || application/json]}" onto public java.lang.Object org.springframework.boot.actuate.endpoint.web.servlet.AbstractWebMvcEndpointHandlerMapping$OperationHandler.handle(javax.servlet.http.HttpServletRequest,java.util.Map<java.lang.String, java.lang.String>)
    

    3.注意

    • @EndPoint中的id不能使用驼峰法,需要以-分割。
    • @Spring Boot会去扫描@EndPoint注解下的@ReadOperation, @WriteOperation, @DeleteOperation注解,分别对应生成Get/Post/Delete的Mapping。注解中有个produces参数,可以指定media type, 如:application/json等。
  • 相关阅读:
    C++ assert()断言
    libcurl API:CURLOPT_REFERER的用法
    hdu 2821 Pusher (dfs)
    快速找到跟踪其他session产生的trc文件
    10635
    pat 1055 区间前k个
    闲话Cache:始篇
    闲话缓存:算法概述
    instance 怎么获得自己的 Metadata
    通过 dhcp-agent 访问 Metadata
  • 原文地址:https://www.cnblogs.com/kancy/p/12358351.html
Copyright © 2011-2022 走看看