為了保障業務穩定性,通常採用多個ACK叢集對等部署的方式來實現高可用。雲原生API Gateway支援多ACK叢集接入,通過一個網關執行個體同時關聯多個叢集,將同名服務合并,在多個服務端點之間做負載平衡。搭配網關的健康檢測功能,自動探測服務可用性,實現更高效的故障自動切流。本文以兩個ACK叢集為例,介紹如何通過雲原生API Gateway管理多個ACK叢集。
前提條件
建立兩個ACK叢集。具體操作,請參見建立ACK託管叢集。
在兩個叢集中配置同名的服務。以
httpbin服務為例,樣本配置如下所示。
背景資訊
在生產實踐中,若對業務穩定性要求非常高,通常會採用多ACK叢集對等部署的方式來保障高可用。例如,叢集A部署在可用性區域A,叢集B部署在可用性區域B,A與B兩個叢集部署的服務一致,當其中一個叢集故障時可以快速切換流量。
雲原生API Gateway為了支援業務的高可用部署訴求,提供了多ACK叢集接入功能。即用一個雲原生API Gateway執行個體同時關聯A、B兩個叢集,網關會將兩個叢集的同名服務進行合并,合并後的服務名稱與原來保持一致,但是服務的IP地址清單會同時包含兩個服務的所有IP地址。如果A或者B叢集故障,利用雲原生API Gateway的路由能力會自動將流量分發到正常叢集。推薦搭配網關的主動健康檢測功能一起使用,由網關主動探測服務的IP地址可用性,從而帶來更高效的故障自動切流。
如下圖所示,雲原生API Gateway管理著來自兩個ACK叢集的A、B兩個服務。當ACK叢集B發生crash時,仍然能夠通過網關訪問到叢集A的A、B兩個服務,且該切流動作自動發生,無需人工幹涉。

步驟一:在雲原生API Gateway中添加Container Service來源
在左側導覽列,選擇執行個體,並在頂部功能表列選擇地區。
在執行個體頁面,單擊目標網關執行個體名稱。
在左側導覽列,選擇服務,並單擊來源頁簽。
單擊建立來源。在建立來源面板,選擇來源類型為Container Service,並配置相關參數,然後單擊確定。具體操作,請參見建立服務來源。

步驟二:在雲原生API Gateway中分別添加服務A與B
在左側導覽列,選擇執行個體,並在頂部功能表列選擇地區。
在執行個體頁面,單擊目標網關執行個體名稱。
在左側導覽列,選擇服務,並單擊服務頁簽。
單擊建立服務。在建立服務面板,選擇服務來源為Container Service,並選擇命名空間和服務列表,然後單擊確定。具體操作,請參見建立服務。

步驟三:在雲原生API Gateway中為目標服務添加路由配置
建立HTTP API,具體操作,請參見建立HTTP API。
單擊目標API,在左上方單擊建立路由。
在建立路由頁面,配置相關參數,然後單擊儲存並發布。具體操作,請參見建立路由。

結果驗證
當叢集A、B正常時
在服務列表頁面查看服務地址。
可觀察到服務地址中有兩條記錄。

多次訪問網關,具體代碼如下所示,可看到會返回兩個不同的hostname。
curl <網關存取點網域名稱>/version
當叢集A異常時
在叢集A中刪除httpbin服務。
此時,服務地址只有一條記錄。

多次訪問網關,具體代碼如下所示,可看到hostname只有一個。
curl <網關存取點網域名稱>/version