Http タイムアウト構成

Http タイムアウト(レスポンスと接続)は、すべてのルートに対して構成でき、特定のルートごとにオーバーライドできます。

グローバルタイムアウト

グローバル http タイムアウトを設定するには:
 connect-timeout はミリ秒単位で指定する必要があります。
 response-timeout は java.time.Duration として指定する必要があります

グローバル http タイムアウトの例
spring:
  cloud:
    gateway:
      httpclient:
        connect-timeout: 1000
        response-timeout: 5s

ルートごとのタイムアウト

ルートごとのタイムアウトを設定するには:
 connect-timeout はミリ秒単位で指定する必要があります。
 response-timeout はミリ秒単位で指定する必要があります。

ルートごとの http は、構成を介して構成をタイムアウトします
      - id: per_route_timeouts
        uri: https://example.org
        predicates:
          - name: Path
            args:
              pattern: /delay/{timeout}
        metadata:
          response-timeout: 200
          connect-timeout: 200
JavaDSL を使用したルートごとのタイムアウト設定
import static org.springframework.cloud.gateway.support.RouteMetadataUtils.CONNECT_TIMEOUT_ATTR;
import static org.springframework.cloud.gateway.support.RouteMetadataUtils.RESPONSE_TIMEOUT_ATTR;

      @Bean
      public RouteLocator customRouteLocator(RouteLocatorBuilder routeBuilder){
         return routeBuilder.routes()
               .route("test1", r -> {
                  return r.host("*.somehost.org").and().path("/somepath")
                        .filters(f -> f.addRequestHeader("header1", "header-value-1"))
                        .uri("http://someuri")
                        .metadata(RESPONSE_TIMEOUT_ATTR, 200)
                        .metadata(CONNECT_TIMEOUT_ATTR, 200);
               })
               .build();
      }

負の値を持つルートごとの response-timeout は、グローバル response-timeout 値を無効にします。

      - id: per_route_timeouts
        uri: https://example.org
        predicates:
          - name: Path
            args:
              pattern: /delay/{timeout}
        metadata:
          response-timeout: -1