Actuator API
/gateway 执行器端点允许您监视 Spring Cloud Gateway 应用程序并与其交互。`/gateway` 执行器端点默认禁用访问。要启用该端点,您需要将访问权限设置为'read-only' 或 'unrestricted',并在应用程序属性中通过 HTTP 或 JMX 公开它。以下清单显示了如何操作
management.endpoint.gateway.access=read-only
management.endpoints.web.exposure.include=gateway
建议您将 management.endpoint.gateway.access 设置为 read-only。这将禁用刷新、创建和删除路由的功能。如果您需要使用执行器端点创建、刷新和删除路由的功能,您需要将 management.endpoint.gateway.access 设置为 unrestricted 或设置 management.endpoint.gateway.enabled=true。如果您启用通过执行器端点创建、删除和刷新路由的功能,您应该采取适当的步骤来确保您的执行器端点是安全的。 |
此端点提供了子执行器端点上可用的内容的概览以及每个引用的可用方法。结果响应类似于以下内容
[
{
"href":"/actuator/gateway/",
"methods":[ "GET" ]
},
{
"href":"/actuator/gateway/routedefinitions",
"methods":[ "GET" ]
},
{
"href":"/actuator/gateway/globalfilters",
"methods":[ "GET" ]
},
{
"href":"/actuator/gateway/routefilters",
"methods":[ "GET" ]
},
{
"href":"/actuator/gateway/routes",
"methods":[ "POST", "GET" ]
},
{
"href":"/actuator/gateway/routepredicates",
"methods":[ "GET" ]
},
{
"href":"/actuator/gateway/refresh",
"methods":[ "POST" ]
},
{
"href":"/actuator/gateway/routes/route-id-1/combinedfilters",
"methods":[ "GET" ]
},
{
"href":"/actuator/gateway/routes/route-id-1",
"methods":[ "POST", "DELETE", "GET" ]
}
]
详细执行器格式
Spring Cloud Gateway 中添加了一种新的、更详细的格式。它为每个路由添加了更多细节,让您可以查看与每个路由关联的谓词和过滤器以及任何可用的配置。以下示例配置了 /actuator/gateway/routes
[
{
"predicate": "(Hosts: [**.addrequestheader.org] && Paths: [/headers], match trailing slash: true)",
"route_id": "add_request_header_test",
"filters": [
"[[AddResponseHeader X-Response-Default-Foo = 'Default-Bar'], order = 1]",
"[[AddRequestHeader X-Request-Foo = 'Bar'], order = 1]",
"[[PrefixPath prefix = '/httpbin'], order = 2]"
],
"uri": "lb://testservice",
"order": 0
}
]
此功能默认启用。要禁用它,请设置以下属性
spring.cloud.gateway.actuator.verbose.enabled=false
这将在未来版本中默认为 true。
检索路由过滤器
本节详细介绍了如何检索路由过滤器,包括
全局过滤器
要检索应用于所有路由的全局过滤器,请向 /actuator/gateway/globalfilters 发出 GET 请求。结果响应类似于以下内容
{
"org.springframework.cloud.gateway.filter.ReactiveLoadBalancerClientFilter@77856cc5": 10100,
"org.springframework.cloud.gateway.filter.RouteToRequestUrlFilter@4f6fd101": 10000,
"org.springframework.cloud.gateway.filter.NettyWriteResponseFilter@32d22650": -1,
"org.springframework.cloud.gateway.filter.ForwardRoutingFilter@106459d9": 2147483647,
"org.springframework.cloud.gateway.filter.NettyRoutingFilter@1fbd5e0": 2147483647,
"org.springframework.cloud.gateway.filter.ForwardPathFilter@33a71d23": 0,
"org.springframework.cloud.gateway.filter.AdaptCachedBodyGlobalFilter@135064ea": 2147483637,
"org.springframework.cloud.gateway.filter.WebsocketRoutingFilter@23c05889": 2147483646
}
响应包含已启用的全局过滤器的详细信息。对于每个全局过滤器,都有一个过滤器对象的字符串表示(例如,org.springframework.cloud.gateway.filter.ReactiveLoadBalancerClientFilter@77856cc5)以及过滤器链中对应的顺序。
路由过滤器
要检索应用于路由的GatewayFilter 工厂,请向 /actuator/gateway/routefilters 发出 GET 请求。结果响应类似于以下内容
{
"[AddRequestHeaderGatewayFilterFactory@570ed9c configClass = AbstractNameValueGatewayFilterFactory.NameValueConfig]": null,
"[SecureHeadersGatewayFilterFactory@fceab5d configClass = Object]": null,
"[SaveSessionGatewayFilterFactory@4449b273 configClass = Object]": null
}
响应包含应用于任何特定路由的 GatewayFilter 工厂的详细信息。对于每个工厂,都有一个相应对象的字符串表示(例如,[SecureHeadersGatewayFilterFactory@fceab5d configClass = Object])。请注意,null 值是由于端点控制器实现不完整造成的,因为它试图设置对象在过滤器链中的顺序,这不适用于 GatewayFilter 工厂对象。
刷新路由缓存
要清除路由缓存,请向 /actuator/gateway/refresh 发出 POST 请求。该请求返回 200,不带响应正文。
要清除具有特定元数据值的路由,请添加查询参数 metadata,指定要清除的路由应匹配的 key:value 对。如果在异步刷新期间产生错误,刷新将不会修改现有路由。
向 /actuator/gateway/refresh?metadata=group:group-1 发送 POST 请求将只刷新其 group 元数据为 group-1 的路由:first_route 和 third_route。
[{
"route_id": "first_route",
"route_object": {
"predicate": "...",
},
"metadata": { "group": "group-1" }
},
{
"route_id": "second_route",
"route_object": {
"predicate": "...",
},
"metadata": { "group": "group-2" }
},
{
"route_id": "third_route",
"route_object": {
"predicate": "...",
},
"metadata": { "group": "group-1" }
}]
检索网关中定义的路由
要检索网关中定义的路由,请向 /actuator/gateway/routes 发出 GET 请求。结果响应类似于以下内容
[{
"route_id": "first_route",
"route_object": {
"predicate": "org.springframework.cloud.gateway.handler.predicate.PathRoutePredicateFactory$$Lambda$432/1736826640@1e9d7e7d",
"filters": [
"OrderedGatewayFilter{delegate=org.springframework.cloud.gateway.filter.factory.PreserveHostHeaderGatewayFilterFactory$$Lambda$436/674480275@6631ef72, order=0}"
]
},
"order": 0
},
{
"route_id": "second_route",
"route_object": {
"predicate": "org.springframework.cloud.gateway.handler.predicate.PathRoutePredicateFactory$$Lambda$432/1736826640@cd8d298",
"filters": []
},
"order": 0
}]
响应包含网关中定义的所有路由的详细信息。下表描述了响应中每个元素(每个元素都是一个路由)的结构
| 路径 | 类型 | 描述 |
|---|---|---|
|
字符串 |
路由 ID。 |
|
对象 |
路由谓词。 |
|
数组 |
应用于路由的 |
|
数字 |
路由顺序。 |
检索特定路由的信息
要检索单个路由的信息,请向 /actuator/gateway/routes/{id} 发出 GET 请求(例如,/actuator/gateway/routes/first_route)。结果响应类似于以下内容
{
"id": "first_route",
"predicates": [{
"name": "Path",
"args": {"_genkey_0":"/first"}
}],
"filters": [],
"uri": "https://www.uri-destination.org",
"order": 0
}
下表描述了响应的结构
| 路径 | 类型 | 描述 |
|---|---|---|
|
字符串 |
路由 ID。 |
|
数组 |
路由谓词的集合。每个项定义给定谓词的名称和参数。 |
|
数组 |
应用于路由的过滤器集合。 |
|
字符串 |
路由的目标 URI。 |
|
数字 |
路由顺序。 |
创建和删除特定路由定义
要创建路由定义,请向 /gateway/routes/{id_route_to_create} 发出 POST 请求,并附带一个指定路由字段的 JSON 正文(参见检索特定路由的信息)。
要删除路由定义,请向 /gateway/routes/{id_route_to_delete} 发出 DELETE 请求。
创建多个路由定义
要在单个请求中创建多个路由定义,请向 /gateway/routes 发出 POST 请求,并附带一个指定路由字段(包括路由 ID)的 JSON 正文(参见检索特定路由的信息)。
如果在创建路由期间任何路由引发错误,则路由定义将被丢弃。
回顾:所有端点的列表
下表总结了 Spring Cloud Gateway 执行器端点(请注意,每个端点都以 /actuator/gateway 作为基本路径)
| ID | HTTP 方法 | 描述 |
|---|---|---|
|
GET |
显示应用于路由的全局过滤器列表。 |
|
GET |
显示应用于特定路由的 |
|
POST |
清除路由缓存。 |
|
GET |
显示网关中定义的路由列表。 |
|
GET |
显示特定路由的信息。 |
|
POST |
向网关添加新路由。 |
|
DELETE |
从网关中移除现有路由。 |