<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                ## 流量轉移/分流 **注意:本文是為v1 API編寫的,但這些概念也適用于v2 API。它將在未來版本的v2 API中重新描述。** Envoy路由器支持將流量分發到兩個或更多上游虛擬主機群集的路由。有兩種常見的場景。 1. 版本升級:到一條路由的流量逐漸從一個集群轉移到另一個集群。更詳細地描述參見流量轉移部分。 2. A/B測試或多重測試:同時測試兩個或更多版本的相同服務。流向路由的流量必須在運行不同版本相同服務的集群之間進行拆分。更詳細地描述參見流量分流部分。 ### 上游主機間的流量轉移 在路由運行時配置對象中,確定選擇指定路由(以及它的集群)的概率。通過使用運行時配置,虛擬主機中指定路由的流量可逐漸從一個集群轉移到另一個集群。參考以下配置示例,其中名為`helloworld`的服務,在Envoy配置文件中聲明`helloworld_v1`和`helloworld_v2`兩個版本。 ``` { "route_config": { "virtual_hosts": [ { "name": "helloworld", "domains": ["*"], "routes": [ { "prefix": "/", "cluster": "helloworld_v1", "runtime": { "key": "routing.traffic_shift.helloworld", "default": 50 } }, { "prefix": "/", "cluster": "helloworld_v2", } ] } ] } } ``` Envoy匹配策略是匹配第一個路由。如果路由具有運行時配置對象,則會根據使用運行時值進行匹配(如果沒有指定值,則為默認值)。因此,通過在上面的例子中緊挨著的兩條路由配置,通過在第一個路由中指定一個運行時對象,并且改變隨著時間推移,修改該運行時對象的值來實現流量轉移。以下是完成任務所需的大致操作順序。 1. 在開始時,將`routing.traffic_shift.helloworld`設置為`100`,以便所有對`helloworld`服務的請求,都與v1的路由匹配,并由`helloworld_v1`集群提供服務。 2. 要開始將流量轉移到`helloworld_v2`集群時,請將`routing.traffic_shift.helloworld`設置為`0<x<100`范圍內。例如,設置`90`,對`helloworld`虛擬主機的每10個請求中,有1個將不匹配v1的路由,并將落入v2路由,由`helloworld_v2`集群提供服務。 3. 逐漸設置`routing.traffic_shift.helloworld`中的值變小,以便更大比例的請求匹配到v2路由。 4. 當`routing.traffic_shift.helloworld`設置為0時,對`helloworld`虛擬主機的請求將不會匹配v1路由。現在所有的流量都會流向v2路由,并由`helloworld_v2`集群提供服務。 ### 多上游主機的流量分流 再次參考`helloworld`的例子,現在有三個版本(v1,v2和v3),而不是兩個。 要在三個版本(即33%,33%,34%)之間平均分配流量,可以使用`weighted_clusters`選項指定每個上游群集的權重。 與前面的例子不同,一個路由條目就足夠了。路由中的`weighted_clusters`配置可用于指定多個上游群集以及引導每個發送到上游群集的流量百分比權重。 ``` { "route_config": { "virtual_hosts": [ { "name": "helloworld", "domains": ["*"], "routes": [ { "prefix": "/", "weighted_clusters": { "runtime_key_prefix" : "routing.traffic_split.helloworld", "clusters" : [ { "name" : "helloworld_v1", "weight" : 33 }, { "name" : "helloworld_v2", "weight" : 33 }, { "name" : "helloworld_v3", "weight" : 34 } ] } } ] } ] } } ``` 可以使用以下運行時變量動態調整分配給每個群集的權重:<br /> `routing.traffic_split.helloworld.helloworld_v1` `routing.traffic_split.helloworld.helloworld_v2` `routing.traffic_split.helloworld.helloworld_v3`。 ## 返回 - [上一級](../HTTPconnectionmanager.md) - [首頁目錄](../../README.md)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看