本文說明如何復原 Pub/Sub 主題的結構定義。
復原作業可讓您建立另一個結構定義修訂版本,並使用指定先前修訂版本的確切結構定義。
事前準備
- 瞭解 Pub/Sub 結構定義的運作方式。
- 建立結構定義。
必要角色和權限
如要取得還原及管理結構定義所需的權限,請要求管理員授予您專案的「Pub/Sub 編輯者」 (roles/pubsub.editor
) 身分與存取權管理角色。如要進一步瞭解如何授予角色,請參閱「管理專案、資料夾和機構的存取權」。
這個預先定義的角色具備回溯及管理結構定義所需的權限。如要查看確切的必要權限,請展開「必要權限」部分:
所需權限
如要回溯及管理結構定義,必須具備下列權限:
-
建立結構定義:
pubsub.schemas.create
-
將結構定義附加至主題:
pubsub.schemas.attach
-
提交結構定義修訂版本:
pubsub.schemas.commit
-
刪除結構定義或結構定義修訂版本:
pubsub.schemas.delete
-
取得結構定義或結構定義修訂版本:
pubsub.schemas.get
-
列出結構定義:
pubsub.schemas.list
-
列出結構定義修訂版本:
pubsub.schemas.listRevisions
-
回溯結構定義:
pubsub.schemas.rollback
-
驗證訊息:
pubsub.schemas.validate
-
取得結構定義的身分與存取權管理政策:
pubsub.schemas.getIamPolicy
-
設定結構定義的 IAM 政策:
pubsub.schemas.setIamPolicy
您可以將角色和權限授予主體,例如使用者、群組、網域或服務帳戶。您可以在一個專案中建立結構定義,並將其附加至位於其他專案的主題。請確認您具備每個專案的必要權限。
復原結構定義修訂版本
您可以使用Trusted Cloud 控制台、gcloud CLI、Pub/Sub API 或 Cloud 用戶端程式庫,還原結構定義。步驟如下:
控制台
前往 Trusted Cloud 控制台的「Pub/Sub schemas」(Pub/Sub 結構定義) 頁面。
按一下現有結構定義的名稱。
系統會開啟結構定義的「結構定義詳細資料」頁面。
按一下「復原」。
「Roll back schema」(還原結構定義) 對話方塊隨即開啟。
選取要將結構定義復原至哪一個修訂版本。
按一下「確認」,儲存回溯作業。
系統會使用復原作業中指定的結構定義,建立新的修訂版本。
在「結構定義詳細資料」頁面中,選取最新版本的結構定義,以及您選取做為復原作業來源的版本。
按一下「查看差異」。
您可以確認這兩個結構定義是否完全相同。
您可以將剛建立的結構定義修訂版本做為驗證主題的最新版本,方法是更新「上次允許使用的修訂版本」欄位。
gcloud
gcloud pubsub schemas rollback SCHEMA_ID \ --revision-id=REVISION_ID
其中:
- REVISION_ID 是要復原的修訂版本。
REST
如要回溯結構定義,請傳送類似下列內容的 POST 要求:
POST https://pubsub.googleapis.com/v1/projects/PROJECT_ID/schemas/SCHEMA_ID:rollback Authorization: Bearer $(gcloud auth application-default print-access-token) Content-Type: application/json --data @response-body.json
指定以下要求主體欄位:
{ "revisionId": REVISION_KD }
其中:
- REVISION_KD 是要復原的修訂版本 ID。
回應主體應包含結構定義資源的 JSON 表示法。
C++
在試用這個範例之前,請先按照快速入門:使用用戶端程式庫中的 C++ 設定操作說明進行操作。詳情請參閱 Pub/Sub C++ API 參考說明文件。
Go
以下範例使用 Go Pub/Sub 用戶端程式庫的主要版本 (v2)。如果您仍在使用第 1 版程式庫,請參閱第 2 版遷移指南。如要查看第 1 版程式碼範例清單,請參閱 已淘汰的程式碼範例。
在試用這個範例之前,請先按照快速入門:使用用戶端程式庫中的 Go 設定說明進行操作。詳情請參閱 Pub/Sub Go API 參考說明文件。
Java
在試用這個範例之前,請先按照快速入門:使用用戶端程式庫中的 Java 設定操作說明進行操作。詳情請參閱 Pub/Sub Java API 參考說明文件。
Python
在試用這個範例之前,請先按照快速入門:使用用戶端程式庫中的 Python 設定操作說明來進行。詳情請參閱 Pub/Sub Python API 參考說明文件。
Node.js
在嘗試這個範例之前,請先按照快速入門:使用用戶端程式庫中的 Node.js 設定說明進行操作。詳情請參閱 Pub/Sub Node.js API 參考說明文件。
Node.js
在嘗試這個範例之前,請先按照快速入門:使用用戶端程式庫中的 Node.js 設定說明進行操作。詳情請參閱 Pub/Sub Node.js API 參考說明文件。