14. 这DiscoveryClient路径定义定位器
您可以将网关配置为基于向DiscoveryClient兼容的服务注册表。
要启用此功能,请将spring.cloud.gateway.discovery.locator.enabled=true并确保DiscoveryClient实现(例如 Netflix、Eureka、Consul 或 Zookeeper)位于类路径上并已启用。
14.1. 配置谓词和过滤器DiscoveryClient路线
默认情况下,网关为使用DiscoveryClient.
默认谓词是使用 pattern 定义的路径谓词/serviceId/**哪里serviceId是
服务的 ID 来自DiscoveryClient.
默认过滤器是带有正则表达式的重写路径过滤器/serviceId/?(?<remaining>.*)和替换/${remaining}.
这会在请求向下游发送之前从路径中剥离服务 ID。
如果要自定义DiscoveryClient路线, 设置spring.cloud.gateway.discovery.locator.predicates[x]和spring.cloud.gateway.discovery.locator.filters[y].
这样做时,如果要保留该功能,则需要确保包含前面显示的默认谓词和过滤器。
以下示例显示了它的外观:
实施例 70.应用程序属性
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}'"