建立從 Google Cloud 啟動的連線

本頁說明如何從 Google Cloud啟動,成功建立及佈建 Amazon Web Services (AWS) 合作夥伴 Cross-Cloud Interconnect 連線。

如果您沒有 AWS 提供的啟用金鑰,可以從Google Cloud啟動及佈建 AWS 連線的合作夥伴 Cross-Cloud Interconnect。

開始佈建 AWS 合作夥伴 Cross-Cloud Interconnect 之前,請確認符合下列條件:

  • 您必須已擁有 Amazon Web Services 帳戶。
  • 如果沒有虛擬私有雲 (VPC) 網路,您也必須建立一個,才能將傳輸連線至該網路。

如要成功建立連線,您必須建立 transport 資源。請按照下列操作說明建立傳輸作業。

事前準備

開始設定前,請先詳閱下列各節。

建立或選取專案

如要輕鬆設定 AWS 適用的合作夥伴 Cross-Cloud Interconnect,請先找出有效的專案。

  1. Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  3. Verify that billing is enabled for your Google Cloud project.

  4. Install the Google Cloud CLI.

  5. 若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI

  6. 執行下列指令,初始化 gcloud CLI:

    gcloud init
  7. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  8. Verify that billing is enabled for your Google Cloud project.

  9. Install the Google Cloud CLI.

  10. 若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI

  11. 執行下列指令,初始化 gcloud CLI:

    gcloud init
  12. 如果您使用 Google Cloud CLI,請使用 gcloud config set 指令設定專案 ID。

    gcloud config set project PROJECT_ID

    PROJECT_ID 替換為專屬專案 ID。

    這個頁面的 gcloud CLI 指令假設您已設定專案 ID。

  13. 如要確認專案 ID 設定正確無誤,請使用 gcloud config list 指令

    gcloud config list --format='text(core.project)'
  14. 啟用 Network Connectivity API

    您必須先啟用 Network Connectivity API,才能使用 Cloud Interconnect 執行任何工作。

    控制台

    如要啟用 Network Connectivity API,請按照下列步驟操作:

    1. 前往 Google Cloud 控制台的「Network Connectivity API」頁面。

      前往 Network Connectivity API

    2. 按一下「啟用」

    或者,您也可以使用Google Cloud 控制台 API 程式庫啟用 API,如「啟用 API」一文所述。

    如果沒有啟動金鑰,請從 Google Cloud 啟動連線

    列出可用的設定檔

    如要在您想佈建連線的區域中,列出特定專案的可用設定檔,請按照下列步驟操作。

    API

    使用 networkconnectivity.remoteTransportProfiles.list 方法,並將要求主體留空。

    $ curl -H "Authorization: Bearer $(gcloud auth print-access-token)" "https://networkconnectivity.googleapis.com/v1beta/projects/PROJECT/locations/LOCATION/remoteTransportProfiles"
    

    替換下列值:

    • PROJECT:專案名稱
    • LOCATION:您要佈建連線的 Google Cloud 區域 名稱,例如 us-west1

    建立 transport 資源

    transport 資源建立過程中,您必須指定頻寬、網路、remoteProfileremoteAccountId 欄位。advertisedRoutes 是選填欄位,但為確保 AWS 的連線能力,您必須指定這個欄位。這個欄位可以是 IPv4 和 IPv6 子網路的清單。 如果網路使用自動子網路建立功能,請使用 10.128.0.0/9 Google Cloud中的值。

    如要建立傳輸資源,請按照下列步驟操作。

    API

    使用 networkconnectivity.transports.create 方法指定 TRANSPORT_ID,類似於下列範例:

    curl -X POST -H "Authorization: Bearer $(gcloud auth print-access-token)" -H "Content-Type: application/json" "https://networkconnectivity.googleapis.com/v1beta/projects/PROJECT/locations/LOCATION/transports?="TRANSPORT_ID" --data '{
    "network": "NETWORK",
    "remoteProfile": "REMOTE_PROFILE",
    "bandwidth": "BANDWIDTH",
    "remoteAccountId": "AWS_ACCOUNT_ID",
    "advertisedRoutes": ["IP_RANGE_1","IP_RANGE_2"],
    "stackType": "STACK_TYPE
    }'
    

    替換下列值:

    • PROJECT:您要在當中建立傳輸作業的專案名稱
    • LOCATION:您要佈建連線的 Google Cloud 區域 名稱,例如 us-west1
    • TRANSPORT_ID:傳輸資源的名稱
    • NETWORK:要建立傳輸的網路
    • REMOTE_PROFILE:您要佈建連線的設定檔
    • BANDWIDTH:連線的所選頻寬,例如 BPS_1G
    • AWS_ACCOUNT_ID:您的 AWS 帳戶 ID
    • IP_RANGE:以半形逗號分隔的 IP 位址範圍清單
    • STACK_TYPE (選用):IP 位址版本堆疊類型。必須為 IPV4_ONLYIPV4_IPV6。預設值為 IPV4_ONLY

    在輸出中,找出 name 欄位的值。格式為 projects/PROJECT/locations/LOCATION/operations/OPERATION_ID,其中 OPERATION_ID 是作業的 ID。

    如要查看作業狀態,請使用 networkconnectivity.operations.get 方法

    GET https://networkconnectivity.googleapis.com/v1/locations/LOCATION/operations/OPERATION_ID
    

    更改下列內容:

    • LOCATION:您要佈建連線的 Google Cloud 區域 名稱,例如 us-west1
    • OPERATION_ID:作業 ID

    如果 transport 資源已建立完成,輸出內容會包含 "done": true 行。從輸出內容複製下列值,以供後續步驟使用:

    • generatedActivationKey 欄位的值
    • peeringNetwork 欄位的值

    完成 AWS API 的步驟

    按照 AWS API 參考文件中的操作說明,使用您在上一個步驟中產生的啟用金鑰。

    建立虛擬私有雲網路對等互連

    您可以在Google Cloud 結尾主動建立虛擬私有雲網路對等互連。如要執行這項操作,請使用先前建立的 transport 資源傳回的 peeringNetwork,並確保您建立的對等互連具有相同的堆疊類型。預設堆疊類型與 transport 資源 (使用 IPV4_ONLY) 相符。

    如要接收 AWS 路由,請啟用 Import custom routes 欄位。

    對等互連虛擬私有雲網路中的 MTU 會明確設為最大值,以免連線發生 MTU 問題。如果使用的 MTU 小於 8896,可能會收到 WARNING: Some requests generated warnings: - Network MTU 1460B does not match the peer's MTU 8896B 警告。在這種情況下,請務必確保 Google Cloud 虛擬私有雲網路和 AWS 虛擬私有雲網路使用相符的 MTU 設定。如果這些值不相符,您可能需要將 MTU 值覆寫為最低公分母。舉例來說,如果您在 Google Cloud 中使用 8896,在 AWS 中使用 8800,則 Google Cloud 中的所有項目都必須設為 8800。

    gcloud

    如要建立虛擬私有雲網路對等互連,請使用 gcloud compute networks peerings create 指令

    gcloud compute networks peerings create "TRANSPORT_NAME" \
        --network="VPC_NETWORK"
        --peer-network="PEERING_NETWORK" \
        --import-custom-routes
        --export-custom-routes
    

    替換下列值:

    • TRANSPORT_NAME:您建立的傳輸方式名稱
    • VPC_NETWORK:要列出路徑的虛擬私有雲網路名稱
    • PEERING_NETWORK:虛擬私有雲網路的名稱,由 Transport 資源提供,您從 transport 資源的 peeringNetwork 欄位複製而來

    如果指令成功執行,輸出內容的 state 欄位會顯示 ACTIVE 值。

    API

    如要建立虛擬私有雲網路對等互連,請使用 compute.networks.addPeering 方法

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT/global/networks/NETWORK/addPeering
    

    替換下列值:

    • PROJECT:對等互連專案的名稱
    • NETWORK:要新增對等互連的網路資源名稱

    確認連線

    您可以列出對等互連的虛擬私有雲網路和路徑表,確認連線已建立。完成 AWS 設定後,您可以在清單中查看 AWS 路由。

    gcloud

    如要列出對等互連的虛擬私有雲網路,請使用 gcloud compute networks peerings list 指令

    gcloud compute networks peerings list
    

    輸出結果會與下列內容相似:

    DEST_RANGE   TYPE                   NEXT_HOP_REGION  PRIORITY  STATUS
    10.0.0.0/16  DYNAMIC_PEERING_ROUTE  us-east4         0         accepted
    10.0.0.0/16  DYNAMIC_PEERING_ROUTE  us-east4         0         accepted
    

    如要列出特定傳輸的路線,請使用 gcloud compute networks peerings list-routes 指令

    gcloud compute networks peerings list-routes TRANSPORT_ID\
        --direction=INCOMING \
        --network=NETWORK \
        --region=LOCATION
    

    替換下列值:

    • TRANSPORT_ID:傳輸資源的名稱
    • NETWORK:要列出路由表的虛擬私有雲網路名稱
    • LOCATION:傳輸資源的位置

    API

    如要列出對等互連網路,請使用 compute.networks.list 方法

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT/global/networks
    

    PROJECT 替換為要列出網路的專案名稱。

    如要列出路徑,請使用 compute.routes.listPeeringRoutes 方法

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT/global/networks/NETWORK/listPeeringRoutes
    

    替換下列值:

    • PROJECT,這是您要列出路徑的專案名稱
    • NETWORK:要列出路由表的虛擬私有雲網路名稱

    後續步驟