DiscoveryClient 路由定义定位器
您可以配置网关以根据在 DiscoveryClient 兼容的服务注册表中注册的服务来创建路由。
默认情况下,创建的路由使用协议 lb://service-name(其中 service-name 是 DiscoveryClient::getServices 返回的字符串),这意味着它们是负载均衡的。因此,您还需要包含 org.springframework.cloud:spring-cloud-starter-loadbalancer 依赖项,以便其在类路径中可用。
要启用此功能,请设置 spring.cloud.gateway.discovery.locator.enabled=true 并确保 DiscoveryClient 实现(例如 Netflix Eureka、Consul、Zookeeper 或 Kubernetes)在类路径中并已启用。
为 DiscoveryClient 路由配置谓词和过滤器
默认情况下,网关为使用 DiscoveryClient 创建的路由定义一个谓词和一个过滤器。
默认谓词是一个路径谓词,使用模式 /serviceId/** 定义,其中 serviceId 是来自 DiscoveryClient 的服务 ID。
默认过滤器是一个路径重写过滤器,其正则表达式为 /serviceId/?(?<remaining>.*),替换为 /${remaining}。这会在请求发送到下游之前从路径中剥离服务 ID。
如果您想自定义 DiscoveryClient 路由使用的谓词或过滤器,请设置 spring.cloud.gateway.discovery.locator.predicates[x] 和 spring.cloud.gateway.discovery.locator.filters[y]。这样做时,如果您想保留该功能,则需要确保包含前面所示的默认谓词和过滤器。以下示例显示了在属性和 yaml 格式中的样子
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}'"
spring:
cloud:
gateway:
discovery:
locator:
predicates:
- name: Host
args:
pattern: "'**.foo.com'"
- name: Path
args:
pattern: "'/'+serviceId+'/**'"
filters:
- name: CircuitBreaker
args:
name: serviceId
- name: RewritePath
args:
regexp: "'/' + serviceId + '/?(?<remaining>.*)'"
replacement: "'/${remaining}'"