配置

Spring Cloud Gateway 的配置由一组 RouteDefinitionLocator 实例驱动。以下列表展示了 RouteDefinitionLocator 接口的定义

RouteDefinitionLocator.java
public interface RouteDefinitionLocator {
	Flux<RouteDefinition> getRouteDefinitions();
}

默认情况下,PropertiesRouteDefinitionLocator 使用 Spring Boot 的 @ConfigurationProperties 机制加载属性。

早期的配置示例都使用了使用位置参数而非命名参数的快捷方式。以下两个示例是等效的

application.yml
spring:
  cloud:
    gateway:
      routes:
      - id: setstatus_route
        uri: https://example.org
        filters:
        - name: SetStatus
          args:
            status: 401
      - id: setstatusshortcut_route
        uri: https://example.org
        filters:
        - SetStatus=401

对于网关的一些用法,属性是足够的,但有些生产用例得益于从外部源(如数据库)加载配置。未来的里程碑版本将提供基于 Spring Data Repositories(如 Redis、MongoDB 和 Cassandra)的 RouteDefinitionLocator 实现。

路由定义指标

要启用 RouteDefinition 指标,请添加 spring-boot-starter-actuator 作为项目依赖。然后,默认情况下,只要属性 spring.cloud.gateway.metrics.enabled 设置为 true,指标就可用。将添加一个名为 spring.cloud.gateway.routes.count 的仪表指标,其值是 RouteDefinition 的数量。此指标将从 /actuator/metrics/spring.cloud.gateway.routes.count 获取。