選取您的 Cookie 偏好設定

我們使用提供自身網站和服務所需的基本 Cookie 和類似工具。我們使用效能 Cookie 收集匿名統計資料,以便了解客戶如何使用我們的網站並進行改進。基本 Cookie 無法停用,但可以按一下「自訂」或「拒絕」以拒絕效能 Cookie。

如果您同意,AWS 與經核准的第三方也會使用 Cookie 提供實用的網站功能、記住您的偏好設定,並顯示相關內容,包括相關廣告。若要接受或拒絕所有非必要 Cookie,請按一下「接受」或「拒絕」。若要進行更詳細的選擇,請按一下「自訂」。

GitHub 和 GitHub Enterprise Server 的 GitHub 應用程式連線

焦點模式
GitHub 和 GitHub Enterprise Server 的 GitHub 應用程式連線 - AWS CodeBuild

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

您可以使用 GitHub 應用程式與 CodeBuild 連線。透過 支援 GitHub 應用程式連線AWS CodeConnections

來源提供者存取可讓您使用 GitHub Webhook 事件 CreateWebhook 訂閱 或在 CodeBuild 教學課程:設定 CodeBuild 託管的 GitHub 動作執行器中使用 來觸發組建。

注意

CodeConnections 在比 CodeBuild 更少的區域中可用。您可以在 CodeBuild 中使用跨區域連線。在選擇加入區域中建立的連線,無法在其他區域中使用。如需詳細資訊,請參閱 AWS CodeConnections 端點和配額

步驟 1:建立 GitHub 應用程式的連線 (主控台)

使用這些步驟來使用 CodeBuild 主控台在 GitHub 中為您的專案新增連線。

建立連至 GitHub 的連線
注意

您可以使用從另一個帳戶共用的連線,而不是在帳戶中建立或使用現有的連線 AWS 。如需詳細資訊,請參閱與 AWS 帳戶共用連線

步驟 2:授予 CodeBuild 專案 IAM 角色存取權以使用連線

您可以授予 CodeBuild 專案 IAM 角色存取權,以使用連線提供的 GitHub 權杖。

授予 CodeBuild 專案 IAM 角色存取權
  1. 遵循 CodeBuild 專案的 指示允許 CodeBuild 與其他 AWS 服務互動,為您的 CodeBuild 專案建立 IAM 角色。

  2. 遵循指示時,將下列 IAM 政策新增至 CodeBuild 專案角色,以授予連線的存取權。

    { "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "codeconnections:GetConnectionToken", "codeconnections:GetConnection" ], "Resource": [ <connection-arn> ] } ] }

步驟 3:設定 CodeBuild 以使用新的連線

您可以將連線設定為帳戶層級登入資料,並在專案中使用。

AWS Management Console
在 中將連線設定為帳戶層級登入資料 AWS Management Console
  1. 針對 Source provider (來源供應商),選擇 GitHub

  2. 針對登入資料,請執行下列其中一項操作:

    • 選擇預設來源登入資料,以使用您帳戶的預設來源登入資料套用至所有專案。

      1. 如果您未連線至 GitHub,請選擇管理預設來源憑證

      2. 針對登入資料類型,選擇 GitHub 應用程式

      3. 連線中,選擇使用現有的連線或建立新的連線。

    • 選擇自訂來源登入資料,以使用自訂來源登入資料來覆寫帳戶的預設設定。

      1. 針對登入資料類型,選擇 GitHub 應用程式

      2. 連線中,選擇使用現有的連線或建立新的連線。

AWS CLI
在 中將連線設定為帳戶層級登入資料 AWS CLI
  • 開啟終端機 (Linux、macOS 或 Unix) 或命令提示 (Windows)。使用 AWS CLI 來執行 import-source-credentials命令,--token為您的連線指定 --auth-type--server-type和 。

    使用下列命令:

    aws codebuild import-source-credentials --auth-type CODECONNECTIONS --server-type GITHUB --token <connection-arn>
在 中將連線設定為帳戶層級登入資料 AWS Management Console
  1. 針對 Source provider (來源供應商),選擇 GitHub

  2. 針對登入資料,請執行下列其中一項操作:

    • 選擇預設來源登入資料,以使用您帳戶的預設來源登入資料套用至所有專案。

      1. 如果您未連線至 GitHub,請選擇管理預設來源憑證

      2. 針對登入資料類型,選擇 GitHub 應用程式

      3. 連線中,選擇使用現有的連線或建立新的連線。

    • 選擇自訂來源登入資料,以使用自訂來源登入資料來覆寫帳戶的預設設定。

      1. 針對登入資料類型,選擇 GitHub 應用程式

      2. 連線中,選擇使用現有的連線或建立新的連線。

您也可以為 CodeBuild 專案設定多個字符。如需詳細資訊,請參閱將多個字符設定為來源層級登入資料

對 GitHub 應用程式的問題進行故障診斷

下列資訊可協助您對 GitHub App 的常見問題進行故障診斷。

在不需要的區域安裝 AWS Connector for GitHub 應用程式

問題:您從 GitHub Marketplace 安裝 AWS 了 Connector for GitHub,但連線是在不需要的區域建立的。如果您嘗試在 GitHub 網站上重新設定應用程式,它將無法運作,因為應用程式已安裝在您的 GitHub 帳戶上。

可能原因:應用程式已安裝在您的 GitHub 帳戶中,因此您只能重新設定應用程式許可。

建議的解決方案:您可以在所需區域中使用安裝 ID 建立新的連線。

  1. 開啟位於 https://console.aws.amazon.com/codesuite/settings/connections://www. 的 CodeConnections 主控台,並使用 AWS 主控台導覽列中的區域選擇器導覽至所需的區域。

  2. 請遵循開發人員工具使用者指南建立 GitHub 連線的說明。

    注意

    由於您已安裝 AWS Connector for GitHub 應用程式,因此可以選擇它,而不是安裝新的應用程式。

GitHub 應用程式連線無法存取儲存庫

問題:使用連線 AWS 的服務,例如 CodeBuild 或 CodePipeline,報告它無法存取儲存庫或儲存庫不存在。一些可能的錯誤訊息包括:

  • Authentication required for primary source.

  • Unable to create webhook at this time. Please try again later.

  • Failed to create webhook. GitHub API limit reached. Please try again later.

可能原因:您可能已使用 GitHub 應用程式,但尚未授予 Webhook 許可範圍。

建議的解決方案:若要授予所需的許可範圍,請遵循導覽至您要檢閱或修改的 GitHub 應用程式中的指示,以設定已安裝的應用程式。在許可區段下,您會看到應用程式沒有 Webhook 許可,而且您可以選擇檢閱新請求的許可。檢閱並接受新的許可。如需詳細資訊,請參閱核准 GitHub 應用程式的更新許可

可能原因:連線如預期般運作,但突然無法存取儲存庫。

可能的解決方法:從檢閱您的授權安裝開始,然後驗證 GitHub 應用程式是否已授權並安裝。如果 GitHub 應用程式安裝已暫停,則需要將其取消暫停。如果 GitHub 應用程式未獲授權進行 UAT (使用者存取字符) 連線,或未針對 IAT (安裝存取字符) 連線安裝,則現有的連線將無法再使用,而且您將需要建立新的連線。請注意,重新安裝 GitHub 應用程式不會復原與舊安裝相關聯的先前連線。

可能的解決方案:如果連線是 UAT 連線,請確定未同時使用連線,例如在多個 CodeBuild 並行執行組建中使用 。這是因為如果連線重新整理了過期的字符,GitHub 會立即使先前發行的 UAT 失效。如果您需要將 UAT 連線用於多個並行 CodeBuild 組建,您可以建立多個連線並獨立使用每個連線。

可能的解決方案:如果在過去 6 個月內未使用 UAT 連線,GitHub 會將連線失效。若要修正此問題,請建立新的連線。

可能原因:您可能已在未安裝應用程式的情況下使用 UAT 連線。

建議的解決方案:雖然建立 UAT 連線不需要將連線與 GitHub 應用程式安裝建立關聯,但需要安裝 才能存取儲存庫。遵循指示來檢閱安裝,以確保已安裝 GitHub 應用程式。如果未安裝,請導覽至 GitHub 應用程式頁面以安裝應用程式。如需 UAT 存取的詳細資訊,請參閱關於使用者存取字符

AWS 服務的 IAM 角色缺少必要的 IAM 許可。

問題:您會看到下列任何錯誤訊息:

  • Access denied to connection <connection-arn>

  • Failed to get access token from <connection-arn>

建議的解決方案:通常您使用 AWS 服務的連線,例如 CodePipeline 或 CodeBuild。當您為 AWS 服務提供 IAM 角色時, AWS 服務可以使用角色的許可來代表您採取行動。確定 IAM 角色具有必要的許可。如需必要 IAM 許可的詳細資訊,請參閱《 開發人員工具主控台使用者指南》中的授予 CodeBuild 專案 IAM 角色存取權,以使用AWS CodeStar 通知和 CodeConnections 的連線和身分和存取管理

隱私權網站條款Cookie 偏好設定
© 2025, Amazon Web Services, Inc.或其附屬公司。保留所有權利。