本頁面提供應用程式運算子 (AO) 的操作說明,說明如何從匯出的金鑰管理系統 (KMS) 金鑰執行金鑰匯入作業。AO 會使用下列資源的 kubectl
指令列介面 (CLI) 執行匯入和匯出作業:
如要進一步瞭解這些資源,請參閱「KMS API 總覽」。
如要查看 KMS 支援金鑰的完整清單和詳細資料,請參閱「金鑰管理系統 (KMS)」頁面的「支援的金鑰」一節。
事前準備
請務必備妥下列資訊再繼續操作:
設定為存取 Management API 伺服器的
kubectl
指令。如要這麼做,請按照「取得 kubeconfig 檔案」和「gcloud 指令列介面 (CLI)」一節的說明操作。KMS 金鑰匯入管理員和 KMS 金鑰匯出管理員角色。如要取得匯入匯出金鑰所需的權限,請要求平台管理員 (PA) 授予您 KMS 金鑰匯入管理員 (
kms-keyimport-admin
) 和 KMS 金鑰匯出管理員 (kms-keyexport-admin
) 角色。
匯入匯出的金鑰
如要匯入匯出的金鑰,請完成下列步驟:
建立 YAML 檔案,並將
KeyImport
資源新增為kind
物件的值:apiVersion: "kms.gdc.goog/v1" kind: KeyImport metadata: name: KEY_IMPORT_NAME namespace: PROJECT spec: context: mechanism: MECHANISM
請替換下列變數:
- KEY_IMPORT_NAME:
KeyImport
資源的名稱,例如:key-import-test
。 - PROJECT:專案命名空間的名稱,例如:
kms-test1
。 - MECHANISM:金鑰的分享機制,例如:`EDCH_P521_AES256`。
- KEY_IMPORT_NAME:
將 YAML 檔案的內容套用至 KMS,並建立
KeyImport
資源:kubectl apply -f FILENAME.yaml
將 FILENAME 換成 YAML 檔案的名稱。
KMS 會使用內部產生的金鑰組公開金鑰,將
KeyImport
資源的狀態更新為AwaitingKeyToImport
。如要繼續,您必須查看資源狀態並取得 KMS 產生的公開金鑰。如要查看
KeyImport
資源的狀態,並取得 KMS 產生的公開金鑰,請執行下列指令:kubectl describe keyimport KEY_IMPORT_NAME --namespace PROJECT
請替換下列變數:
- KEY_IMPORT_NAME:
KeyImport
資源名稱,例如key-import-test
。 - PROJECT:專案命名空間的名稱,例如
kms-test1
。
執行指令後,您會看到類似下方的輸出內容:
... Status: Conditions: Last Transition Time: 2022-12-14T20:43:50Z Message: waiting for user to provide KeyToImport Observed Generation: 1 Reason: AwaitingKeyToImport Status: False Type: Ready Imported Key Ref: Kind: KeyImport Name: key-import-test Peer Context: Private Key: Public Key: PUBLIC_KEY Events: <none>
值 PUBLIC_KEY 代表 KMS 產生的公開金鑰。複製公開金鑰,並在下一個步驟中將其新增至
KeyExport
資源。- KEY_IMPORT_NAME:
建立另一個 YAML 檔案,將
KeyExport
資源新增為kind
物件的值,並加入下列內容:apiVersion: "kms.gdc.goog/v1" kind: KeyExport metadata: name: KEY_EXPORT_NAME namespace: PROJECT spec: context: mechanism: MECHANISM publicKey: PUBLIC_KEY keyToExport: kind: KEY_PRIMITIVE name: KEY_NAME
請替換下列變數:
- KEY_EXPORT_NAME:
KeyExport
資源的名稱,例如:key-export-test
。 PROJECT:專案命名空間的名稱,例如
kms-test1
。MECHANISM:金鑰的分享機制,例如:`EDCH_P521_AES256`。
PUBLIC_KEY:來自
keyImport.Status.PeerContext.PublicKey
的公開金鑰。KEY_PRIMITIVE:金鑰的 CRD,例如 aeadkey 和 signingkey。
KEY_NAME:金鑰名稱,例如
key-1
。
- KEY_EXPORT_NAME:
將 YAML 檔案的內容套用至 KMS,並建立
KeyExport
資源:kubectl apply -f FILENAME.yaml
將 FILENAME 換成 YAML 檔案的名稱。
執行指令後,KMS 會更新
KeyExport
資源的狀態,並產生匯出的金鑰。如要取得匯出的金鑰,請查看資源的狀態。如要查看資源的狀態,請執行下列指令:
kubectl describe keyexport KEY_EXPORT_NAME --namespace PROJECT
請替換下列變數:
- KEY_EXPORT_NAME:資源的名稱,例如
key-export-test
。KeyExport
- PROJECT:專案命名空間的名稱,例如:
kms-test1
。
執行指令後,您會看到類似以下的輸出內容:
... Status: Conditions: Last Transition Time: 2022-12-14T20:45:57Z Message: key successfully exported Observed Generation: 1 Reason: KeyExportCompleted Status: True Type: Ready Exported Key: EXPORTED_KEY
EXPORTED_KEY 代表匯出金鑰的中繼資料。複製 EXPORTED_KEY 中的內容,繼續執行下一個步驟。
- KEY_EXPORT_NAME:資源的名稱,例如
編輯包含
KeyImport
資源的 YAML 檔案,並加入從keyexport.status.exportedkey
輸出內容複製的內容。apiVersion: "kms.gdc.goog/v1" kind: KeyImport metadata: name: key-import-test namespace: kms-test1 spec: context: mechanism: EDCH_P521_AES256 keyToImport: EXPORTED_KEY
編輯 YAML 檔案後,請將內容套用至 KMS:
kubectl apply -f FILENAME.yaml
執行指令後,KMS 會匯入您提供的匯出金鑰。
如要查看匯入金鑰的詳細資料,請執行下列指令:
kubectl get keyimport KEY_IMPORT_NAME
畫面會顯示類似以下內容的輸出:
NAMESPACE NAME AGE READY REASON KEY KIND kms-test1 KEY_IMPORT_NAME 60s True KeyImportCompleted KEY_PRIMITIVE
KEY_PRIMITIVE 代表您匯入的金鑰類型,介於 AEAD 和簽署金鑰之間。