本頁說明如何使用資料庫移轉服務,將 SQL Server 資料庫遷移至 SQL Server 適用的 Cloud SQL 執行個體。
遷移程序包含下列工作:
從來源 SQL Server 執行個體匯出完整資料庫備份和交易記錄檔案。
您也可以在遷移程序中使用選用的差異資料庫備份。
將備份檔案上傳至 Cloud Storage bucket。
建立 SQL Server 適用的 Cloud SQL 目的地執行個體。
在資料庫移轉服務建立及執行移轉工作。
使用資料庫移轉服務的可觀察性功能監控遷移工作進度。
在資料完整移轉後推送移轉工作。
費用
對於同質遷移作業,如果資料庫引擎的來源和目的地相同,不必支付額外費用即可使用資料庫移轉服務。不過,Cloud SQL 和 Cloud Storage 的定價適用於網路費用,以及為了遷移作業而建立的 Cloud SQL 和 Cloud Storage 實體。
在本文件中,您將使用Google Cloud的下列計費元件:
- Cloud Storage
- Cloud SQL
如要根據預測用量產生預估費用,請使用Pricing Calculator。
事前準備
- 確認這個遷移路徑是否能完全支援您的情況。請參閱「SQL Server 已知限制」。
- 請考量要建立目的地資料庫的區域。資料庫移轉服務是全區域產品,也就是說,與遷移作業相關的所有實體 (來源和目的地連線設定檔、遷移工作、目的地資料庫、儲存體值區) 都必須儲存在單一區域。
- 在 Google Cloud 控制台中,選取專案選擇器頁面中的專案,或 建立 Google Cloud 專案。
- 啟用資料庫移轉服務、Compute Engine、Cloud Storage 和 Cloud SQL Admin API。
必要的角色
如要取得使用資料庫遷移服務執行同類 SQL Server 遷移作業所需的權限,請要求管理員為以下 遷移程序中涉及的帳戶,授予專案中必要的 IAM 角色
- 執行遷移作業的使用者帳戶:
-
資料庫遷移管理員 (
roles/datamigration.admin
) -
Storage 管理員 (
roles/storage.admin
) -
Cloud SQL 編輯器 (
roles/cloudsql.editor
)
-
資料庫遷移管理員 (
- 資料庫移轉服務服務帳戶:
-
資料庫遷移管理員 (
roles/datamigration.admin
) -
Storage 管理員 (
roles/storage.admin
) -
Cloud SQL 編輯器 (
roles/cloudsql.editor
) -
Cloud SQL Studio 使用者 (
roles/cloudsql.studioUser
)
-
資料庫遷移管理員 (
如要進一步瞭解如何授予角色,請參閱「 管理存取權」一文。
這些預先定義的角色具備使用資料庫移轉服務執行同類 SQL Server 遷移作業所需的權限。如要查看確切的必要權限,請展開「必要權限」部分:
所需權限
如要使用資料庫移轉服務執行相同系統的 SQL Server 遷移作業,必須具備下列權限:
- 執行遷移作業的使用者帳戶:
datamigration.*
resourcemanager.projects.get
resourcemanager.projects.list
cloudsql.operations.get
cloudsql.instances.create
cloudsql.instances.get
cloudsql.instances.list
cloudsql.instances.import
cloudsql.databases.get
cloudsql.databases.list
cloudsql.databases.delete
compute.machineTypes.list
compute.machineTypes.get
compute.projects.get
storage.buckets.create
storage.buckets.list
- 資料庫移轉服務服務帳戶:
datamigration.*
resourcemanager.projects.get
resourcemanager.projects.list
cloudsql.instances.create
cloudsql.instances.get
cloudsql.instances.list
cloudsql.instances.executeSql
storage.objects.create
storage.objects.list
您或許還可透過 自訂角色或其他 預先定義的角色取得這些權限。
準備來源資料
如要準備要移轉的來源資料,請按照下列步驟操作:
考量遷移程序的備份策略。資料庫遷移服務支援使用差異備份和交易記錄檔案,以便在您完成完整備份後,遷移資料庫中顯示的資料。
對來源 SQL Server 資料庫執行完整備份。請務必使用正確的命名模式。
準備 Cloud Storage 值區,並將備份檔案上傳至該值區。請務必為每種要使用的備份檔案類型設定必要的目錄結構。
為 Cloud Storage 值區 建立來源連線設定檔。
準備 SQL Server 適用的 Cloud SQL 目的地執行個體
如要設定目的地 Cloud SQL 執行個體,請執行下列步驟:
建立及設定 Cloud SQL for SQL Server 目的地執行個體。請務必使用足夠的運算和記憶體資源來滿足遷移需求,並將「儲存空間管理員」(
roles/storage.admin
) 角色指派給執行個體的服務帳戶。為 Cloud SQL 執行個體建立目的地連線設定檔。
建立及執行遷移工作
如要設定及執行遷移作業,請執行下列步驟:
-
啟動遷移工作後,SQL Server 適用的 Cloud SQL 目的地資料庫會進入復原模式,由資料庫移轉服務全權管理。資料完整遷移後,您可以推送目的地執行個體。目的地執行個體升級後,該執行個體中的所有資料庫都會完全運作。您也將獲得這些資料庫的完整寫入權限。
您可以使用資料庫移轉服務的可觀察性功能,監控遷移進度和目的地執行個體的健康狀況。請參閱 遷移工作指標。
持續將新的交易記錄備份檔案上傳至 Cloud Storage 值區。
如要涵蓋執行完整備份匯出作業後在來源資料庫中顯示的資料,請 匯出交易記錄備份檔案,然後上傳至儲存值區。資料庫遷移服務會自動偵測新檔案、讀取內容,並將資料推送至目的地執行個體。請參閱「 自動匯出交易記錄」。
完成遷移
決定將應用程式切換至新的 Cloud SQL for SQL Server 執行個體後,請按照下列步驟完成遷移作業:
- 停止來源資料庫的所有寫入作業。您可以將這些檔案切換為唯讀模式,保留運作功能。
- 請備份最新的交易記錄,將檔案上傳至儲存體 bucket,並停止資料庫遷移服務中的增量載入階段。您可以執行下列任一動作來達到這個結果:
- 停止 自動備份檔案上傳,或上傳最後的交易記錄檔案。監控 未處理的交易記錄備份大小,判斷資料庫移轉服務何時完成處理該檔案。
- 您可以選擇上傳名稱結尾為
.trn.final
後置字串的交易記錄檔案。資料庫遷移服務偵測到備份檔案名稱符合.trn.final
後置字串慣例時,就會停止持續載入。
- 推送遷移工作。
- (選用) 驗證遷移資料是否完整。