【Timeout】超时策略

ASM支持设定指定应用程序在被视为不健康之前可以无响应的时间,即被允许的请求响应延迟时间。本文介绍如何配置超时策略。

前提条件

已完成准备工作,并部署httpbin服务和sleep服务。具体操作,请参见准备工作

操作步骤

  1. 验证服务配置是否生效。

    1. 在ACK集群对应的KubeConfig环境下,执行以下命令,进入sleep环境开启bash。

      kubectl exec -it deploy/sleep -- sh
    2. 执行以下命令,向httpbin服务发送请求,要求延迟1秒响应。

      curl -I httpbin:8000/delay/1

      预期输出:

      HTTP/1.1 200 OK
      server: envoy
      date: Fri, 11 Aug 2023 09:57:36 GMT
      content-type: application/json
      content-length: 481
      access-control-allow-origin: *
      access-control-allow-credentials: true
      x-envoy-upstream-service-time: 1006

      预期输出表明响应延迟了1秒。

    3. 执行以下命令,向httpbin服务发送请求,要求延迟2秒响应。

      curl -I httpbin:8000/delay/2

      预期输出:

      HTTP/1.1 200 OK
      server: envoy
      date: Fri, 11 Aug 2023 09:57:26 GMT
      content-type: application/json
      content-length: 481
      access-control-allow-origin: *
      access-control-allow-credentials: true
      x-envoy-upstream-service-time: 2004

      预期输出表明响应延迟了2秒。

  2. 使用以下内容,构建测试场景,配置httpbin应用的流量规则,设置允许的timeout时间为2s。具体操作,请参见管理虚拟服务

  3. apiVersion: networking.istio.io/v1beta1
    kind: VirtualService
    metadata:
      name: httpbin-vs
      namespace: default
    spec:
      hosts:
        - httpbin
      http:
        - route:
            - destination:
                host: httpbin
          timeout: 2s
  4. 验证配置是否生效。

    1. 在ACK集群对应的KubeConfig环境下,执行以下命令,进入sleep环境开启bash。

      kubectl exec -it deploy/sleep -- sh
    2. 执行以下命令,向httpbin服务发送请求,设置响应延迟1秒返回。

      curl -I httpbin:8000/delay/1

      预期输出:

      HTTP/1.1 200 OK
      server: envoy
      date: Fri, 11 Aug 2023 09:56:30 GMT
      content-type: application/json
      content-length: 481
      access-control-allow-origin: *
      access-control-allow-credentials: true
      x-envoy-upstream-service-time: 1005

      预期输出表明响应延迟1秒返回。

    3. 执行以下命令,向httpbin服务发送请求,设置响应延迟2秒返回。

      curl -I httpbin:8000/delay/2

      预期输出:

      HTTP/1.1 504 Gateway Timeout
      content-length: 24
      content-type: text/plain
      date: Fri, 11 Aug 2023 09:56:35 GMT
      server: envoy

      返回504错误,表明超时策略生效。