API Proxy 設定參考資料

您目前查看的是 Apigee Edge 說明文件。
前往 Apigee X 說明文件
info

如果您是使用 Apigee Edge 的開發人員,主要開發活動包括設定 API Proxy,做為 API 或後端服務的 Proxy。本文是建構 API Proxy 時可用的所有設定元素參考資料。

如果您正在學習如何建構 API Proxy,建議先從「建構簡單的 API Proxy」主題開始。

編輯 Proxy 設定最常見的方法如下:

在本機開發 Proxy 設定

您可以下載 Proxy 設定,在本機電腦上編輯。完成後,請將結果上傳至 Edge。這種方法可讓您將 Proxy 設定整合至原始碼控管、版本控管和其他共用工作流程。此外,您可以在本機處理 Proxy 設定,並使用自己的 XML 編輯器和驗證工具。

本節說明如何使用 UI 下載現有的 Proxy 設定、編輯設定,然後上傳回 Edge 進行部署。您也可以使用 apigeetool 下載及部署新的 Proxy 設定 (分別使用 fetchproxydeployproxy 指令)。

如要透過 UI 在本機編輯 Proxy 設定,請按照下列步驟操作:

  1. 在 Edge 使用者介面中下載目前的 Proxy 設定。(在「API Proxy」檢視畫面中,依序選取「Project」>「Download Revision」)。
  2. 在本機電腦上建立新目錄,然後將下載的 ZIP 檔案解壓縮到該目錄。

    如要展開 ZIP 檔案,可以使用 unzip 等公用程式,如下列範例所示:

    mkdir myappdir
    unzip ./my-app_app_rev3_2019_04_20.zip -d myappdir

    展開 ZIP 檔案內容後,結構應與「API Proxy 結構」一文所述的結構類似。

  3. 視需要編輯來源檔案。如要瞭解 Proxy 設定中的來源檔案,請參閱「API Proxy 的設定檔和目錄結構」。

    舉例來說,如要在 API Proxy 中啟用健康狀態監控,請編輯 /apiproxy/targets/ 目錄中的 TargetEndpoint 設定檔。這個目錄中的預設檔案是 default.xml,但如果您使用條件式目標,檔案名稱可能會不同。

    在這種情況下,如果 TargetEndpoint 設定檔及其目錄不存在,請建立這些檔案和目錄。

  4. 編輯完 Proxy 設定檔後,請務必儲存變更。
  5. 切換至您在展開 ZIP 檔案時建立的新目錄 (展開設定檔的根目錄)。

    舉例來說,如果將檔案解壓縮到 /myappdir 目錄,請變更為該目錄,如下例所示:

    cd myappdir

    重新封存 Proxy 設定檔前,您應先切換至這個目錄,因為您不希望 /myappdir 目錄包含在 ZIP 檔案中。ZIP 檔案中的頂層目錄必須是 /apiproxy

  6. 重新封存 Proxy 設定檔,包括新檔案或變更的檔案。您可以使用 zip 等公用程式,如下列範例所示:
    zip my-new-proxy.zip -r .

    ZIP 檔案中的頂層目錄必須是 /apiproxy

    ZIP 檔案名稱沒有特殊規定,舉例來說,您不需要遞增修訂版本號碼或在檔案名稱中指定日期,但這麼做有助於偵錯或來源控制。

    上傳新的 Proxy 設定時,Edge 會自動遞增修訂版本號碼。

  7. 使用 Edge UI 上傳新的 Proxy 設定。(在「API Proxy」檢視畫面中,依序選取「Project」>「Upload a New Revision」)。

    如果收到類似 Bundle is invalid. Empty bundle. 的錯誤訊息,請確認 ZIP 檔案的頂層目錄為 /apiproxy。如果不是,請從展開目錄的根目錄重新封存 Proxy 設定檔。

    上傳新的 Proxy 設定後,Edge 會遞增修訂版本號碼,並顯示在「修訂版本摘要」檢視畫面中。

    透過 UI 上傳新修訂版本後,Edge 不會為您部署。

  8. 部署新的修訂版本。

詳情請參閱 Apigee 社群的「教學課程:如何使用 UI 和 Management API 下載 Proxy」。

API Proxy 結構

API Proxy 包含下列設定:

基本設定 API Proxy 的主要設定。請參閱「基本設定」。
ProxyEndpoint 設定 傳入 HTTP 連線 (從要求應用程式到 Apigee Edge)、要求和回應流程,以及政策附件的設定。請參閱「ProxyEndpoint」。
TargetEndpoint 設定 外送 HTTP 連線 (從 Apigee Edge 到後端服務)、要求和回應流程,以及政策附件的設定。請參閱「TargetEndpoint」。
流程 ProxyEndpoint 和 TargetEndpoint 要求與回應管道,可附加政策。請參閱「流程」。
政策 符合 Apigee Edge 政策結構定義的 XML 格式設定檔。請參閱政策
資源 政策參照的指令碼、JAR 檔案和 XSLT 檔案,用於執行自訂邏輯。請參閱「資源」。

API Proxy 目錄結構和內容

上表中的元件是由下列目錄結構中的設定檔定義:

顯示目錄結構,其中 apiproxy 是根目錄。apiproxy 目錄下方直接列出政策、Proxy、資源和目標目錄,以及 weatherapi.xml 檔案。

API Proxy 的設定檔和目錄結構

本節說明 API Proxy 的設定檔和目錄結構。

基礎設定

/apiproxy/weatherapi.xml

API Proxy 的基本設定,用於定義 API Proxy 的名稱。機構內的名稱不得重複。

設定範例:

<APIProxy name="weatherapi">
</APIProxy>

基礎設定元素

名稱 說明 預設 是否必要?
APIProxy
name API Proxy 的名稱,在機構內不得重複。名稱只能使用下列字元: A-Za-z0-9_- 不適用
revision API Proxy 設定的修訂版本號碼。您不需要明確設定修訂版本號碼,因為 Apigee Edge 會自動追蹤 API Proxy 的目前修訂版本。 不適用
ConfigurationVersion 這個 API Proxy 遵循的 API Proxy 設定結構定義版本。目前唯一支援的值是 majorVersion 4 和 minorVersion 0。這項設定日後可能會用於啟用 API Proxy 格式的演進功能。 4.0
Description API Proxy 的文字說明。如果提供說明,Edge 管理 UI 就會顯示。 不適用
DisplayName 使用者友善名稱,可能與 API Proxy 設定的 name 屬性不同。 不適用
Policies 這個 API Proxy 的 /policies 目錄中的政策清單。通常只有使用 Edge 管理 UI 建立 API Proxy 時,才會看到這個元素。這只是「資訊清單」設定,旨在提供 API Proxy 內容的顯示設定。 不適用
ProxyEndpoints 這個 API Proxy 的 /proxies 目錄中的 ProxyEndpoint 清單。通常只有使用 Edge 管理 UI 建立 API Proxy 時,才會看到這個元素。這只是「資訊清單」設定,旨在提供 API 代理項目內容的顯示設定。 不適用
Resources 這個 API 代理項目的 /resources 目錄中,資源 (JavaScript、Python、Java、XSLT) 的清單。一般來說,只有在使用 Edge 管理 UI 建立 API Proxy 時,才會看到這個元素。這只是「資訊清單」設定,旨在提供 API Proxy 內容的顯示設定。 不適用
Spec 識別與 API Proxy 相關聯的 OpenAPI 規格。這個值會設為規格商店中的網址或路徑。

注意:規格商店僅適用於新版 Edge。如要進一步瞭解規格商店,請參閱「管理及共用規格」。
不適用
TargetServers 此 API Proxy 任何 TargetEndpoint 中參照的 TargetServer 清單。通常只有使用 Edge 管理 UI 建立 API Proxy 時,才會看到這個元素。這只是「資訊清單」設定,旨在提供 API Proxy 內容的顯示設定。 不適用
TargetEndpoints 這個 API Proxy 的 /targets 目錄中的 TargetEndpoint 清單。通常只有使用 Edge 管理 UI 建立 API Proxy 時,才會看到這個元素。這只是「資訊清單」設定,旨在提供 API 代理項目內容的顯示設定。 不適用

ProxyEndpoint

下圖顯示要求/回應流程:

顯示用戶端呼叫 HTTP 服務。要求會先經過 Proxy 端點和目標端點,然後由 HTTP 服務處理。回應會先經過目標端點和 Proxy 端點,再傳回給用戶端。

/apiproxy/proxies/default.xml

ProxyEndpoint 設定會定義 API Proxy 的連入 (面向用戶端) 介面。設定 ProxyEndpoint 時,您會建立網路設定,定義用戶端應用程式 (「應用程式」) 應如何叫用 Proxy API。

下列 ProxyEndpoint 設定會儲存在 /apiproxy/proxies 下方:

<ProxyEndpoint name="default">
  <PreFlow/>
  <Flows/>
  <PostFlow/>
  <HTTPProxyConnection>
    <BasePath>/weather</BasePath>
    <VirtualHost>default</VirtualHost>
  </HTTPProxyConnection>
  <FaultRules/>
  <DefaultFaultRule/>
  <RouteRule name="default">
    <TargetEndpoint>default</TargetEndpoint>
  </RouteRule>
</ProxyEndpoint>

基本 ProxyEndpoint 的必要設定元素包括:

ProxyEndpoint 設定 元素

名稱 說明 預設 是否必要?
ProxyEndpoint
name ProxyEndpoint 的名稱。如果 (在少數情況下) 定義了多個 ProxyEndpoint,則此名稱在 API Proxy 設定中不得重複。名稱只能使用下列字元:A-Za-z0-9._\-$ % 不適用
PreFlow 定義要求或回應的 PreFlow 流程中的政策。 不適用
Flows
定義要求或回應條件式流程中的政策。
不適用
PostFlow
定義要求或回應 PostFlow 流程中的政策。
不適用
HTTPProxyConnection 定義與 API Proxy 相關聯的網路位址和 URI 路徑
BasePath

必要字串,可準確識別 Apigee Edge 用於將傳入訊息路由至適當 API 代理的 URI 路徑。

BasePath 是附加至 API Proxy 基準網址 (例如 http://apifactory-test.apigee.net) 的 URI 片段 (例如 /weather)。BasePath 在環境中必須是唯一的。產生或匯入 API Proxy 時,系統會驗證唯一性。

在基本路徑中使用萬用字元

您可以在 API Proxy 的基本路徑中使用一或多個「*」萬用字元。舉例來說,如果基本路徑為 /team/*/members,用戶端就能呼叫 https://[host]/team/blue/membershttps://[host]/team/green/members,您不必建立新的 API Proxy 來支援新團隊。請注意,系統不支援 /**/。

重要事項:Apigee「不」支援使用萬用字元「*」做為基本路徑的第一個元素。舉例來說,系統「不」支援 /*/search。 如果基本路徑以「*」開頭,Edge 會以特定方式識別有效路徑,因此可能會發生非預期的錯誤。

/
VirtualHost

將 API Proxy 與環境的特定基準網址建立關聯。VirtualHost 是指已命名的設定,可為環境定義一或多個網址。

為 ProxyEndpoint 定義的具名 VirtualHost 會決定 API Proxy 公開的網域和通訊埠,進而決定應用程式用來叫用 API Proxy 的網址。

依預設,系統會為環境定義兩個具名的 VirtualHost:defaultsecure。機構也可以定義自訂網域。如要確保 API Proxy 只能透過 HTTPS 使用,請在 HTTPProxyConnection 中將 VirtualHost 設為 secure

預設
Properties 您可以將一組選用的 HTTP 設定定義為 <ProxyEndpoint> 的屬性。 不適用
FaultRules
定義 ProxyEndpoint 如何處理錯誤。錯誤規則會指定兩個項目:
  • 條件:根據預先定義的錯誤類別、子類別或名稱,指定要處理的錯誤
  • 一或多項政策,用於定義相應 Condition 的錯誤規則行為

請參閱「處理錯誤」。

不適用
DefaultFaultRule

處理其他錯誤規則未明確處理的任何錯誤 (系統、傳輸、訊息或政策)。

請參閱「處理錯誤」。

不適用
RouteRule 定義 ProxyEndpoint 要求管道處理後,傳入要求訊息的目的地。通常 RouteRule 會指向具名的 TargetEndpoint 設定,但也可以直接指向網址。
Name 必要屬性,可提供 RouteRule 的名稱。名稱只能使用下列字元:A-Za-z0-9._\-$ %。舉例來說,Cat2 %_ 是法定姓名。 不適用
Condition (選用) 執行階段用於動態轉送的條件陳述式。舉例來說,條件式 RouteRule 可用於啟用內容型轉送,以支援後端版本控管。 不適用
TargetEndpoint

這是選用字串,用於識別具名的 TargetEndpoint 設定。具名 TargetEndpoint 是指在相同 API Proxy 的 /targets 目錄下定義的任何 TargetEndpoint。

命名 TargetEndpoint 時,請指出要求訊息在 ProxyEndpoint 要求管道處理後,應轉送至何處。請注意,這是選用設定。

ProxyEndpoint 可能會直接呼叫網址。舉例來說,JavaScript 或 Java 資源可擔任 HTTP 用戶端的角色,執行 TargetEndpoint 的基本職責,也就是將要求轉送至後端服務。

不適用
網址 選用字串,定義 ProxyEndpoint 呼叫的出站網路位址,略過可能儲存在 /targets 下的任何 TargetEndpoint 設定 不適用

如何設定 RouteRules

具名 TargetEndpoint 是指 /apiproxy/targets 下的設定檔,RouteRule 會在 ProxyEndpoint 處理要求後,將要求轉送至該設定檔。

舉例來說,下列 RouteRule 會參照設定 /apiproxy/targets/myTarget.xml

<RouteRule name="default">
  <TargetEndpoint>myTarget</TargetEndpoint>
</RouteRule>

直接叫用網址

ProxyEndpoint 也可以直接叫用後端服務。直接叫用網址會略過 /apiproxy/targets 下的任何具名 TargetEndpoints 設定。因此,TargetEndpoint 是選用的 API Proxy 設定,但實際上不建議從 ProxyEndpoint 直接叫用。

舉例來說,下列 RouteRule 會對 http://api.mycompany.com/v2 發出 HTTP 呼叫。

<RouteRule name="default">
  <URL>http://api.mycompany.com/v2</URL>
</RouteRule>

條件式路徑

RouteRules 可以串連,在執行階段支援動態轉送。根據 HTTP 標頭、訊息內容、查詢參數或情境資訊 (例如時間、語言代碼等),將傳入要求直接路由至網址,或路由至具名的 TargetEndpoint 設定,或兩者兼具。

條件式 RouteRule 的運作方式與 Apigee Edge 上的其他條件式陳述式類似。請參閱條件參考資料變數參考資料

舉例來說,下列 RouteRule 組合會先評估傳入要求,驗證 HTTP 標頭的值。如果 HTTP 標頭 routeTo 的值為 TargetEndpoint1,要求就會轉送至名為 TargetEndpoint1 的 TargetEndpoint。如果沒有,系統會將傳入要求轉送至 http://api.mycompany.com/v2

<RouteRule name="MyRoute">
  <Condition>request.header.routeTo = "TargetEndpoint1"</Condition>
  <TargetEndpoint>TargetEndpoint1</TargetEndpoint>
</RouteRule>
<RouteRule name="default">
  <URL>http://api.mycompany.com/v2</URL>
</RouteRule>

空值路徑

您可以定義空值 RouteRule,支援要求訊息不需要轉送至 TargetEndpoint 的情境。如果 ProxyEndpoint 會執行所有必要的處理作業,例如使用 JavaScript 呼叫外部服務,或從 API 服務的鍵/值儲存區擷取資料,這項功能就非常實用。

舉例來說,下列程式碼會定義空值路徑:

<RouteRule name="GoNowhere"/>

有條件的空值路徑可能很有用。在下列範例中,系統會設定空值路徑,在 HTTP 標頭 request.header.X-DoNothing 的值不是 null 時執行。

<RouteRule name="DoNothingOnDemand">
  <Condition>request.header.X-DoNothing != null</Condition>
</RouteRule>

請注意,RouteRule 可以串連,因此條件式空值 Route 通常是 RouteRule 集的其中一個元件,用於支援條件式轉送。

條件為空值的 Route 實用案例是支援快取。使用 Cache 政策設定的變數值,即可設定 API Proxy,在從快取提供項目時執行空值路徑。

<RouteRule name="DoNothingUnlessTheCacheIsStale">
  <Condition>lookupcache.LookupCache-1.cachehit is true</Condition>
</RouteRule>

TargetEndpoint

顯示用戶端呼叫 HTTP 服務。要求會先經過 Proxy 端點和目標端點,然後由 HTTP 服務處理。回應會先經過目標端點和 Proxy 端點,再傳回給用戶端。

TargetEndpoint 相當於 ProxyEndpoint 的輸出端。TargetEndpoint 的功能類似後端服務或 API 的用戶端,會傳送要求並接收回應。

API Proxy 不一定要有 TargetEndpoint。ProxyEndpoints 可設定為直接呼叫網址。沒有 TargetEndpoint 的 API Proxy 通常包含 ProxyEndpoint,可直接呼叫後端服務,或設定為使用 Java 或 JavaScript 呼叫服務。

TargetEndpoint 設定

/targets/default.xml

TargetEndpoint 會定義從 Apigee Edge 到其他服務或資源的出站連線。

以下是 TargetEndpoint 設定範例:

<TargetEndpoint name="default">
  <PreFlow/>
  <Flows/>
  <PostFlow/>
  <HTTPTargetConnection>
    <URL>http://mocktarget.apigee.net</URL>
    <SSLInfo/>
  </HTTPTargetConnection>
  <FaultRules/>
  <DefaultFaultRule/>
  <ScriptTarget/>
  <LocalTargetConnection/>
</TargetEndpoint>

TargetEndpoint 設定 元素

TargetEndpoint 可以透過下列其中一種方式呼叫目標:

  • HTTP(S) 呼叫的 HTTPTargetConnection
  • 本機 Proxy 對 Proxy 鏈結的 LocalTargetConnection
  • 呼叫 Edge 代管 Node.js 指令碼 的 ScriptTarget

請在 TargetEndpoint 中只設定其中一個。

名稱 說明 預設 是否必要?
TargetEndpoint
name TargetEndpoint 的名稱,在 API 代理設定中不得重複。ProxyEndpoint RouteRule 會使用 TargetEndpoint 的名稱,將要求導向至輸出處理程序。名稱只能使用下列字元:A-Za-z0-9._\-$ % 不適用
PreFlow 定義要求或回應的 PreFlow 流程中的政策。 不適用
Flows
定義要求或回應條件式流程中的政策。
不適用
PostFlow
定義要求或回應 PostFlow 流程中的政策。
不適用
HTTPTargetConnection

與子項元素一起指定透過 HTTP 存取的後端資源。

如果您使用 HTTPTargetConnection,請勿設定其他類型的目標連線 (ScriptTarget 或 LocalTargetConnection)。

URL 定義 TargetEndpoint 將要求訊息轉送到的後端服務網路位址。 不適用
LoadBalancer

定義一或多個具名的 TargetServer 設定。具名的 TargetServer 設定可用於負載平衡,定義 2 個以上的端點設定 連線。

您也可以使用 TargetServer,將 API Proxy 設定與具體後端服務端點網址分離。

請參閱「跨後端伺服器負載平衡」。

不適用
Properties 您可以將一組選用的 HTTP 設定定義為 <TargetEndpoint> 的屬性。 不適用
SSLInfo (選用) 在 TargetEndpoint 上定義 TLS/SSL 設定,控管 API Proxy 與目標服務之間的 TLS/SSL 連線。請參閱「TLS/SSL TargetEndpoint Configuration」。 不適用
LocalTargetConnection 連同子項元素,指定要在本機連線的資源,略過負載平衡和訊息處理器等網路特性。

如要指定目標資源,請加入 APIProxy 子項元素 (含 ProxyEndpoint 元素) 或 Path 子項元素。

詳情請參閱「鏈結多個 API Proxy」。

如果您使用 LocalTargetConnection,請勿設定其他類型的目標連線 (HTTPTargetConnection 或 ScriptTarget)。

APIProxy 指定要用做要求目標的 API Proxy 名稱。目標 Proxy 必須與傳送要求的 Proxy 位於相同機構和環境。這是 Path 元素的替代方案。 不適用
ProxyEndpoint 與 APIProxy 搭配使用,可指定目標 Proxy 的 ProxyEndpoint 名稱。 不適用
Path 指定 API Proxy 的端點路徑,做為要求目標。目標 Proxy 必須與傳送要求的 Proxy 位於相同機構和環境。這是使用 APIProxy 的替代方法。 不適用
FaultRules
定義 TargetEndpoint 對錯誤的反應方式。錯誤規則會指定兩個項目:
  • 條件:根據預先定義的錯誤類別、子類別或名稱,指定要處理的錯誤
  • 一或多項政策,用於定義相應 Condition 的錯誤規則行為

請參閱「處理錯誤」。

不適用
DefaultFaultRule

處理未由其他 FaultRule 明確處理的任何錯誤 (系統、傳輸、訊息或政策)。

請參閱「處理錯誤」。

不適用
ScriptTarget
ResourceURL

定義資源類型 (節點) 和主要 Node.js 指令碼的名稱,該指令碼會實作 TargetEndpoint 功能。

<ResourceURL>node://server.js</ResourceURL>

指令碼必須與 API Proxy 的資源檔案一併納入。請參閱將 Node.js 新增至現有 API Proxy

如果您使用 ScriptTarget,請勿設定其他類型的目標連線 (HTTPTargetConnection 或 LocalTargetConnection)。

不適用
EnvironmentVariable

您可以選擇將環境變數傳遞至主要的 Node.js 指令碼。

請參閱「瞭解 Node.js 模組的 Edge 支援」。

不適用
Arguments

選擇性地將引數傳遞至主要的 Node.js 指令碼。

請參閱「瞭解 Node.js 模組的 Edge 支援」。

不適用

TLS/SSL TargetEndpoint 設定

TargetEndpoints 通常需要管理與異質後端基礎架構的 HTTPS 連線。因此,系統支援多項 TLS/SSL 設定。

傳輸層安全標準 (TLS)/安全資料傳輸層 (SSL) TargetEndpoint 設定元素

名稱 說明 預設 是否必要?
SSLInfo
Enabled 指出端點是否已啟用 TLS/SSL。 如果 <URL> 指定 HTTPS 通訊協定,預設值為 true;如果 <URL> 指定 HTTP,預設值則為 false 如果 <URL> 指定 HTTPS,則為 true
TrustStore 含有受信任伺服器憑證的金鑰儲存庫。 不適用
ClientAuthEnabled 開啟輸出用戶端驗證 (雙向 TLS/SSL) 的設定 false
KeyStore 含有用於外送用戶端驗證的私密金鑰的金鑰儲存區 不適用 是 (如果 ClientAuthEnabled 為 true)
KeyAlias 用於外送用戶端驗證的私密金鑰別名 不適用 是 (如果 ClientAuthEnabled 為 true)
Ciphers

支援外送 TLS/SSL 的密碼。如果未指定任何密碼,系統會允許 JVM 可用的所有密碼。

如要限制密碼,請新增下列元素,列出支援的密碼:

<Ciphers>
 <Cipher>TLS_RSA_WITH_3DES_EDE_CBC_SHA</Cipher>
 <Cipher>TLS_RSA_WITH_DES_CBC_SHA</Cipher>
</Ciphers>
不適用
Protocols

出站 TLS/SSL 支援的通訊協定。如未指定通訊協定,系統會允許 JVM 可用的所有通訊協定。

如要限制通訊協定,請新增下列元素,列出支援的通訊協定:

<Protocols>
 <Protocol>TLSv1.1</Protocol>
 <Protocol>TLSv1.2</Protocol>
</Protocols>
不適用
CommonName

如果指定,則為驗證目標憑證通用名稱的值。 這個值僅適用於 TargetEndpoint 和 TargetServer 設定。不適用於 VirtualHost 設定。

根據預設,指定的值會與目標憑證的通用名稱完全相符。 舉例來說,如果使用 *.myhost.com 做為 <CommonName> 的值,只有在目標憑證中指定完全相同的值 *.myhost.com 做為通用名稱時,系統才會比對並驗證目標主機名稱。

您也可以使用 wildcardMatch 屬性,讓 Apigee 執行萬用字元比對。

舉例來說,如果 <CommonName> 元素指定如下: abc.myhost.com

<CommonName wildcardMatch="true">*.myhost.com</CommonName>
不適用

已啟用輸出用戶端驗證的 TargetEndpoint 範例

<TargetEndpoint name="default">
  <HttpTargetConnection>
        <URL>https://myservice.com</URL>
    <SSLInfo>
      <Enabled>true</Enabled>
      <ClientAuthEnabled>true</ClientAuthEnabled>
      <KeyStore>myKeystore</KeyStore>
      <KeyAlias>myKey</KeyAlias>
      <TrustStore>myTruststore</TrustStore>
    </SSLInfo>
  </HttpTargetConnection>
</TargetEndpoint>

如需詳細操作說明,請參閱「設定從 Edge 到後端的 TLS (Cloud 和 Private Cloud)」。

使用流程變數動態設定 TLS/SSL 值

您也可以動態設定 TLS/SSL 詳細資料,以支援彈性的執行階段需求。 舉例來說,如果您的 Proxy 連線至兩個可能不同的目標 (測試目標和正式目標),您可以讓 API Proxy 以程式輔助方式偵測呼叫的環境,並動態設定適當的金鑰儲存區和信任儲存區參照。如要進一步瞭解這個情境,請參閱 Apigee 社群文章「Dynamic SSLInfo for TargetEndpoint using variable reference」,當中也提供可部署的 API Proxy 範例。

在下列範例中,說明如何在 TargetEndpoint 設定中設定 <SSLInfo> 標記,值可在執行階段提供,例如透過 Java Callout、JavaScript 政策或指派訊息政策。使用包含要設定值的訊息變數。

只有下列元素允許使用變數。

<SSLInfo>
    <Enabled>{myvars.ssl.enabled}</Enabled>
    <ClientAuthEnabled>{myvars.ssl.client.auth.enabled}</ClientAuthEnabled>
    <KeyStore>{myvars.ssl.keystore}</KeyStore>
    <KeyAlias>{myvars.ssl.keyAlias}</KeyAlias>
    <TrustStore>{myvars.ssl.trustStore}</TrustStore>
</SSLInfo>

使用參照動態設定 TLS/SSL 值

設定使用 HTTPS 的 TargetEndpoint 時,您必須考量 TLS/SSL 憑證過期,或系統設定變更而需要更新憑證的情況。在 Edge for Private Cloud 安裝中,使用靜態值或流程變數設定 TLS/SSL 時,您可能需要重新啟動 Message Processor。

詳情請參閱「更新 TLS 憑證」。

不過,您可以選擇將 TargetEndpoint 設為使用金鑰儲存區或信任儲存區的參照。使用參照的優點是,您可以更新參照,指向其他金鑰儲存區或信任儲存區,藉此更新 TLS/SSL 憑證,而不必重新啟動訊息處理器。

舉例來說,下方顯示的 TargetEndpoint 會參照金鑰儲存區:

<SSLInfo>
    <Enabled>true</Enabled>
    <ClientAuthEnabled>false</ClientAuthEnabled>
    <KeyStore>ref://keystoreref</KeyStore>
    <KeyAlias>myKeyAlias</KeyAlias>
</SSLInfo>

使用下列 POST API 呼叫,建立名為 keystoreref 的參照:

curl -X POST  -H "Content-Type:application/xml" https://api.enterprise.apigee.com/v1/o/{org_name}/e/{env_name}/references \
-d '<ResourceReference name="keystoreref">
    <Refers>myTestKeystore</Refers>
    <ResourceType>KeyStore</ResourceType>
</ResourceReference>' -u email:password

參照會指定金鑰儲存區的名稱和類型。

使用下列 GET API 呼叫來查看參照:

curl -X GET https://api.enterprise.apigee.com/v1/o/[org_name}/e/{env_name}/references/keystoreref -u uname:password

如要稍後變更參照,指向其他金鑰儲存區,請使用下列 PUT 呼叫,確保別名名稱相同:

curl -X PUT -H "Content-Type:application/xml" https://api.enterprise.apigee.com/v1/o/{org_name}/e/{env_name}/references/keystoreref \
-d '<ResourceReference name="keystoreref">
    <Refers>myNewKeystore</Refers>
    <ResourceType>KeyStore</ResourceType>
</ResourceReference>' -u email:password

TargetEndpoint 搭配目標負載平衡

TargetEndpoints 支援使用三種負載平衡演算法,在多個具名 TargetServer 之間進行負載平衡。

如需詳細操作說明,請參閱「跨後端伺服器負載平衡」。

政策

API Proxy 中的 /policies 目錄包含所有可附加至 API Proxy 中流程的政策。

政策設定元素

名稱 說明 預設 是否必要?
Policy
name

政策的內部名稱。名稱只能使用以下字元:A-Za-z0-9._\-$ %。不過,Edge 管理 UI 會強制執行其他限制,例如自動移除非英數字元。

視需要使用 <DisplayName> 元素,在管理 UI 代理編輯器中,以其他自然語言名稱標示政策。

不適用
enabled

設為 true 即可強制執行政策。

設為 false 即可「關閉」這項政策。即使政策仍附加至流程,系統也不會強制執行。

true
continueOnError

設為 false,在政策失敗時傳回錯誤。這是大多數政策的預期行為。

設為 true,即使政策失敗,流程執行作業仍會繼續。

false
async

注意:這項屬性不會讓政策以非同步方式執行。 在大多數情況下,請保留預設值 false

如果設為 true,政策執行作業會卸載至其他執行緒,讓主執行緒可處理其他要求。離線處理完成後,主執行緒會返回並完成處理訊息流程。在某些情況下,將 async 設為 true 可提升 API Proxy 效能。不過,過度使用非同步作業可能會導致執行緒切換次數過多,進而影響效能。

如要在 API Proxy 中使用非同步行為,請參閱 JavaScript 物件模型

false

政策附件

下圖顯示 API Proxy 流程的執行順序:

顯示用戶端呼叫 HTTP 服務的活動。要求會遇到 ProxyEndpoint 和 TargetEndpoint,兩者都包含觸發政策的步驟。HTTP 服務傳回回應後,TargetEndpoint 會處理該回應,然後 ProxyEndpoint 會在將回應傳回給用戶端前處理該回應。與要求一樣,回應會由步驟中的政策處理。

如上所示:

政策會以處理步驟的形式附加至流程。政策名稱用於參照要以處理步驟強制執行的政策。政策附件的格式如下:

<Step><Name>MyPolicy</Name></Step>

系統會按照政策附加至流程的順序強制執行政策。例如:

<Step><Name>FirstPolicy</Name></Step>
<Step><Name>SecondPolicy</Name></Step>

政策附加設定 元素

名稱 說明 預設 是否必要?
Step
Name 這個步驟定義要執行的政策名稱。 不適用
Condition 決定是否強制執行政策的條件陳述式。如果政策有相關聯的條件,則只有在條件陳述式評估為 true 時,政策才會執行。 不適用

流程

ProxyEndpoint 和 TargetEndpoint 會定義要求和回應訊息的處理管道。處理管道包含要求流程和回應流程。每個要求流程和回應流程都會細分為 PreFlow、一或多個選用的「條件」或「具名」流程,以及 PostFlow。

  • PreFlow:一律會執行。在任何條件式流程之前執行。
  • PostFlow:一律執行。在任何條件式流程後執行。

此外,您可以在 ProxyEndpoint 中新增 PostClientFlow,在回應傳回給要求用戶端應用程式後執行。只有 MessageLogging 政策Google Stackdriver Logging 擴充功能可以附加至這個流程。PostClientFlow 可減少 API Proxy 延遲,並提供資訊供記錄,這些資訊要等到回應傳回給用戶端後才會計算,例如 client.sent.start.timestampclient.sent.end.timestamp。這個流程主要用於測量回應訊息的開始和結束時間戳記之間的時間間隔。

觀看快速操作說明影片

影片:觀看這部短片,瞭解如何在 PostClientFlow 中使用訊息記錄。

以下是附加訊息記錄政策的 PostClientFlow 範例。

    ...
    <PostFlow name="PostFlow">
        <Request/>
        <Response/>
    </PostFlow>
    <PostClientFlow>
        <Request/>
        <Response>
            <Step>
                <Name>Message-Logging-1</Name>
            </Step>
        </Response>
    </PostClientFlow>
    ...

API Proxy 處理管道會依下列順序執行 Flow:

要求管道:

  1. Proxy 要求前置流程
  2. Proxy 要求條件流程 (選用)
  3. Proxy 要求 PostFlow
  4. 目標要求 PreFlow
  5. 目標要求條件流程 (選用)
  6. 目標要求 PostFlow

回覆管道:

  1. 目標回應前置流程
  2. 目標回應條件流程 (選用)
  3. Target Response PostFlow
  4. Proxy Response PreFlow
  5. Proxy 回應條件流程 (選用)
  6. Proxy Response PostFlow
  7. PostClientFlow 回應 (選用)

只有附加政策的流程需要在 ProxyEndpoint 或 TargetEndpoint 設定中設定。只有在 PreFlow 或 PostFlow 處理期間需要強制執行政策時,才需在 ProxyEndpoint 或 TargetEndpoint 設定中指定 PreFlow 和 PostFlow。

與條件流程不同的是,PreFlow 和 PostFlow 元素的順序並不重要,API Proxy 一律會在管道中的適當時間執行每個元素,無論這些元素出現在端點設定中的哪個位置。

條件流程

ProxyEndpoint 和 TargetEndpoint 支援數量不限的條件流程 (也稱為「具名流程」)。

API Proxy 會測試條件流程中指定的條件,如果符合條件,API Proxy 就會執行條件流程中的處理步驟。如果條件不符,系統就會略過條件流程中的處理步驟。系統會按照 API Proxy 中定義的順序評估條件流程,並執行第一個符合條件的流程。

定義條件式流程後,您就能根據下列條件,在 API Proxy 中套用處理步驟:

  • 要求 URI
  • HTTP 動詞 (GET/PUT/POST/DELETE)
  • 查詢參數、標頭和表單參數的值
  • 其他許多類型的條件

舉例來說,下列條件流程指定只有在要求資源路徑為 /accesstoken 時,才會執行。任何路徑為 /accesstoken 的傳入要求都會導致執行此流程,以及附加至流程的任何政策。如果要求路徑不含 /accesstoken 後置字串,流程就不會執行 (但可能會執行其他條件式流程)。

<Flows>
  <Flow name="TokenEndpoint">
    <Condition>proxy.pathsuffix MatchesPath "/accesstoken"</Condition>
    <Request>
      <Step>
        <Name>GenerateAccessToken</Name>
      </Step>
    </Request>
  </Flow>
</Flows>

流程設定元素

名稱 說明 預設 是否必要?
Flow 由 ProxyEndpoint 或 TargetEndpoint 定義的要求或回應處理管道
Name 流程的專屬名稱。 不適用
Condition 條件陳述式,可評估一或多個變數,結果為 True 或 False。除了預先定義的 PreFlow 和 PostFlow 類型,所有 Flow 都必須定義執行條件。 不適用
Request 與「要求」訊息處理程序相關聯的管道 不適用
Response 與「回應」訊息處理作業相關聯的管道 不適用

步驟處理

Apigee Edge 會強制執行條件式 Flow 的循序排序。條件流程會由上而下執行。系統會執行條件評估結果為 true 的第一個條件式流程,且只會執行一個條件式流程。

舉例來說,在下列 Flow 設定中,任何未包含路徑尾碼 /first/second 的連入要求,都會導致 ThirdFlow 執行,強制執行名為 Return404 的政策。

<Flows>
  <Flow name="FirstFlow">
    <Condition>proxy.pathsuffix MatchesPath "/first"</Condition>
    <Request>
      <Step><Name>FirstPolicy</Name></Step>
    </Request>
  </Flow>
  <Flow name="SecondFlow">
    <Condition>proxy.pathsuffix MatchesPath "/second"</Condition>
    <Request>
      <Step><Name>FirstPolicy</Name></Step>
      <Step><Name>SecondPolicy</Name></Step>
    </Request>
  </Flow>
  <Flow name="ThirdFlow">
    <Request>
      <Step><Name>Return404</Name></Step>
    </Request>
  </Flow>
</Flows>

資源

「資源」(用於 API Proxy 的資源檔案) 是指可使用政策附加至流程的指令碼、程式碼和 XSL 轉換。這些指令碼會顯示在管理 UI 中 API 代理編輯器的「Scripts」部分。

如要瞭解支援的資源類型,請參閱「資源檔案」。

資源可以儲存在 API Proxy、環境或機構中。在上述兩種情況中,資源都會在政策中依名稱參照。API 服務會依序從 API Proxy、環境和機構層級解析名稱。

任何環境中的政策都可以參照儲存在機構層級的資源。環境層級儲存的資源可供該環境中的政策參照。儲存在 API Proxy 層級的資源只能由該 API Proxy 中的政策參照。