什么是端点? 端点就是SpringBoot通过web或者jmx的方式向外部暴露应用的信息,或者上下文的信息。SpringCloud-Admin就是根据此技术来进行实现的。他们用到的技术就是@Endpoint,而不是通过自己@GetMapping之类进行实现的。下面小编就带大家一起来学习端点的使用。学会本文后在利用前面我们讲过的autoconfigure的自动化配置后,你就可以开发更高级的SpringBoot应用(非业务系统)。本教程将带你从业务系统开发者转变为研发系统开发者。
用过SpringBoot的同学可能知道,SpringBoot有很多监控端点,比如当我们引入健康监控组件
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
<version>2.6.7</version>
</dependency>
系统就会自动暴露出许多,web端口供外部调用,获取应用的信息,或者上下文的信息。
一、如何定义端点
可以使用@Endpoint
,@WebEndpoint
,@JmxEndpoint
,或者EndpointWebExtension
来实现HTTP方式的端点,可以是传统SpringMVC也可以是最新的Spring WebFlux
@Endpoint
相当于@WebEndpoint
和@JmxEndpoint
的整合。web和jmx方式都支持@WebEndpoint
只会生成web的方式的端点监控
JmxEndpoint
只会生成Jmx的方式监控
Operation | HTTP method |
---|---|
@ReadOperation |
GET |
@WriteOperation |
POST |
@DeleteOperation |
DELETE |
二、路径规则
默认的基础路径是 /actuator
,如果一个端点配置的路径是sessions
,那么它的全路径就是/actuator/sessions
@Component
@WebEndpoint(id = "sessions")
public class MyHealthEndpoint {
@ReadOperation
public Info get(@Selector String name) {
return new Info(name, "23");
}
}
@Selector
的含义是让这个路径变成/actuator/sessions/{name}
我们能从路径上获取一个入参。
三、相关配置
3.1 自定义管理端点路径
management.endpoints.web.base-path = /manage
此配置会将/actuator/sessions/{name}
转换成/manage/sessions/{name}
3.2 自定义管理服务器地址
默认端口和应用的端口是一致的,但是也可以通过配置的方式改变端口
management.server.port = 8081
management.server.address = 127.0.0.1
3.3 激活端点
//激活所有的端点的web方式请求
management.endpoints.web.exposure.include=*
//关闭端点web方式
management.endpoints.web.exposure.exclude=env,beans
//激活所有的JMX方式请求
management.endpoints.jmx.exposure.include=*
3.4 跨域方式请求
//允许跨域的网址
management.endpoints.web.cors.allowed-origins=http://example.com
//允许跨域的方法
management.endpoints.web.cors.allowed-methods=GET,POST
四、总结
最后我们来总结。
其实@WebEndpoint 就相当于声明成一个@RestController
的控制类而请求方法分别被下面注解代替。
Operation | HTTP method |
---|---|
@ReadOperation |
GET |
@WriteOperation |
POST |
@DeleteOperation |
DELETE |