LoadBalancer 过滤器

LoadBalancer 过滤器接受一个 serviceId 参数。LoadBalancerClient 使用它来选择一个实例进行路由。LoadBalancer 过滤器需要在 Java DSL 中显式使用。当使用 LoadBalancer 过滤器时,请使用 org.springframework.cloud.gateway.server.mvc.handler.HandlerFunctions 中的空 http() 方法。

RouteConfiguration.java
import static org.springframework.cloud.gateway.server.mvc.filter.LoadBalancerFilterFunctions.lb;
import static org.springframework.cloud.gateway.server.mvc.handler.GatewayRouterFunctions.route;
import static org.springframework.cloud.gateway.server.mvc.handler.HandlerFunctions.http;

@Configuration
class RouteConfiguration {

    @Bean
    public RouterFunction<ServerResponse> gatewayRouterFunctionsAddReqHeader() {
		return route("api_route")
				.GET("/api/**", http())
					.filter(lb("apiservice"))
					.build();
    }
}

在配置中使用 LoadBalancer 过滤器

LoadBalancer 过滤器可以在配置中使用 lb 方案的 URI(例如 lb://myservice)来使用,它使用 Spring Cloud LoadBalancerClient 来将名称(本例中为 myservice)解析为实际的主机和端口,并替换同一属性中的 URI。以下清单配置了一个 LoadBalancer 过滤器

application.yml
spring:
  cloud:
    gateway:
      mvc:
        routes:
        - id: api_route
          uri: lb://apiservice
          predicates:
          - Path=/api/**
如果使用 lb() 过滤器,它需要放在任何操作路径的过滤器(如 setPath()stripPrefix())之后,否则生成的 URL 可能会不正确。配置中的 lb: 方案处理器会自动将过滤器置于最高优先级。
默认情况下,当 ReactorLoadBalancer 找不到服务实例时,将返回 503
LoadBalancerClient 返回的 ServiceInstanceisSecure 值会覆盖请求 Gateway 时指定的方案。例如,如果请求通过 HTTPS 进入 Gateway,但 ServiceInstance 指示它不安全,则下游请求将通过 HTTP 进行。相反的情况也可能适用。
Gateway 支持所有 LoadBalancer 功能。您可以在 Spring Cloud Commons 文档中阅读更多相关信息。
© . This site is unofficial and not affiliated with VMware.