14. 这DiscoveryClient路径定义定位器

您可以将网关配置为基于向DiscoveryClient兼容的服务注册表。spring-doc.cadn.net.cn

要启用此功能,请将spring.cloud.gateway.discovery.locator.enabled=true并确保DiscoveryClient实现(例如 Netflix、Eureka、Consul 或 Zookeeper)位于类路径上并已启用。spring-doc.cadn.net.cn

14.1. 配置谓词和过滤器DiscoveryClient路线

默认情况下,网关为使用DiscoveryClient.spring-doc.cadn.net.cn

默认谓词是使用 pattern 定义的路径谓词/serviceId/**哪里serviceId是 服务的 ID 来自DiscoveryClient.spring-doc.cadn.net.cn

默认过滤器是带有正则表达式的重写路径过滤器/serviceId/?(?<remaining>.*)和替换/${remaining}. 这会在请求向下游发送之前从路径中剥离服务 ID。spring-doc.cadn.net.cn

如果要自定义DiscoveryClient路线, 设置spring.cloud.gateway.discovery.locator.predicates[x]spring.cloud.gateway.discovery.locator.filters[y]. 这样做时,如果要保留该功能,则需要确保包含前面显示的默认谓词和过滤器。 以下示例显示了它的外观:spring-doc.cadn.net.cn

实施例 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}'"