14. 这DiscoveryClient
路线定义定位器
您可以将网关配置为基于向DiscoveryClient
兼容的服务注册表。
要启用此功能,请将spring.cloud.gateway.discovery.locator.enabled=true
并确保DiscoveryClient
实现(例如 Netflix Eureka、Consul 或 Zookeeper)在 Classpath 上并启用。
14.1. 配置 Predicates 和 FilterDiscoveryClient
路线
默认情况下,网关为使用DiscoveryClient
.
默认谓词是使用 pattern 定义的路径谓词/serviceId/**
哪里serviceId
是
来自DiscoveryClient
.
默认过滤器是带有 regex 的重写路径过滤器/serviceId/?(?<remaining>.*)
和替换/${remaining}
.
这会在将请求发送到下游之前从路径中剥离服务 ID。
如果要自定义DiscoveryClient
路由, 设置spring.cloud.gateway.discovery.locator.predicates[x]
和spring.cloud.gateway.discovery.locator.filters[y]
.
执行此作时,如果要保留该功能,则需要确保包含前面显示的默认谓词和筛选条件。
以下示例显示了这是什么样子的:
例 70.application.properties
spring.cloud.gateway.discovery.locator.predicates[0].name: Path spring.cloud.gateway.discovery.locator.predicates[0].args[pattern]: "'/'+serviceId+'/**'" spring.cloud.gateway.discovery.locator.predicates[1].name: Host spring.cloud.gateway.discovery.locator.predicates[1].args[pattern]: "'**.foo.com'" spring.cloud.gateway.discovery.locator.filters[0].name: CircuitBreaker spring.cloud.gateway.discovery.locator.filters[0].args[name]: serviceId spring.cloud.gateway.discovery.locator.filters[1].name: RewritePath spring.cloud.gateway.discovery.locator.filters[1].args[regexp]: "'/' + serviceId + '/?(?<remaining>.*)'" spring.cloud.gateway.discovery.locator.filters[1].args[replacement]: "'/${remaining}'"