將 SQL Server 資料庫遷移至 SQL Server 適用的 Cloud SQL

本頁說明如何使用資料庫移轉服務,將 SQL Server 資料庫遷移至 SQL Server 適用的 Cloud SQL 執行個體。

遷移程序包含下列工作:

  1. 從來源 SQL Server 執行個體匯出完整資料庫備份和交易記錄檔案。

    您也可以在遷移程序中使用選用的差異資料庫備份。

  2. 將備份檔案上傳至 Cloud Storage bucket。

  3. 建立 SQL Server 適用的 Cloud SQL 目的地執行個體。

  4. 在資料庫移轉服務建立及執行移轉工作。

  5. 使用資料庫移轉服務的可觀察性功能監控遷移工作進度。

  6. 在資料完整移轉後推送移轉工作。

費用

對於同質遷移作業,如果資料庫引擎的來源和目的地相同,不必支付額外費用即可使用資料庫移轉服務。不過,Cloud SQL 和 Cloud Storage 的定價適用於網路費用,以及為了遷移作業而建立的 Cloud SQL 和 Cloud Storage 實體。

在本文件中,您將使用Google Cloud的下列計費元件:

  • Cloud Storage
  • Cloud SQL

如要根據預測用量產生預估費用,請使用Pricing Calculator

事前準備

  1. 確認這個遷移路徑是否能完全支援您的情況。請參閱「SQL Server 已知限制」。
  2. 請考量要建立目的地資料庫的區域。資料庫移轉服務是全區域產品,也就是說,與遷移作業相關的所有實體 (來源和目的地連線設定檔、遷移工作、目的地資料庫、儲存體值區) 都必須儲存在單一區域。
  3. 在 Google Cloud 控制台中,選取專案選擇器頁面中的專案,或 建立 Google Cloud 專案

    前往專案選取器

  4. 啟用資料庫移轉服務、Compute Engine、Cloud Storage 和 Cloud SQL Admin API。

    啟用 API

必要的角色

如要取得使用資料庫遷移服務執行同類 SQL Server 遷移作業所需的權限,請要求管理員為以下 遷移程序中涉及的帳戶,授予專案中必要的 IAM 角色

如要進一步瞭解如何授予角色,請參閱「 管理存取權」一文。

這些預先定義的角色具備使用資料庫移轉服務執行同類 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

您或許還可透過 自訂角色或其他 預先定義的角色取得這些權限。

準備來源資料

如要準備要移轉的來源資料,請按照下列步驟操作:

  1. 考量遷移程序的備份策略。資料庫遷移服務支援使用差異備份和交易記錄檔案,以便在您完成完整備份後,遷移資料庫中顯示的資料。

  2. 對來源 SQL Server 資料庫執行完整備份。請務必使用正確的命名模式。

  3. 準備 Cloud Storage 值區,並將備份檔案上傳至該值區。請務必為每種要使用的備份檔案類型設定必要的目錄結構。

  4. 為 Cloud Storage 值區 建立來源連線設定檔

準備 SQL Server 適用的 Cloud SQL 目的地執行個體

如要設定目的地 Cloud SQL 執行個體,請執行下列步驟:

  1. 建立及設定 Cloud SQL for SQL Server 目的地執行個體。請務必使用足夠的運算和記憶體資源來滿足遷移需求,並將「儲存空間管理員」(roles/storage.admin) 角色指派給執行個體的服務帳戶。

  2. 為 Cloud SQL 執行個體建立目的地連線設定檔

建立及執行遷移工作

如要設定及執行遷移作業,請執行下列步驟:

  1. 建立並執行遷移工作

    啟動遷移工作後,SQL Server 適用的 Cloud SQL 目的地資料庫會進入復原模式,由資料庫移轉服務全權管理。資料完整遷移後,您可以推送目的地執行個體。目的地執行個體升級後,該執行個體中的所有資料庫都會完全運作。您也將獲得這些資料庫的完整寫入權限。

    您可以使用資料庫移轉服務的可觀察性功能,監控遷移進度和目的地執行個體的健康狀況。請參閱 遷移工作指標

  2. 持續將新的交易記錄備份檔案上傳至 Cloud Storage 值區。

    如要涵蓋執行完整備份匯出作業後在來源資料庫中顯示的資料,請 匯出交易記錄備份檔案,然後上傳至儲存值區。資料庫遷移服務會自動偵測新檔案、讀取內容,並將資料推送至目的地執行個體。請參閱「 自動匯出交易記錄」。

完成遷移

決定將應用程式切換至新的 Cloud SQL for SQL Server 執行個體後,請按照下列步驟完成遷移作業:

  1. 停止來源資料庫的所有寫入作業。您可以將這些檔案切換為唯讀模式,保留運作功能。
  2. 請備份最新的交易記錄,將檔案上傳至儲存體 bucket,並停止資料庫遷移服務中的增量載入階段。您可以執行下列任一動作來達到這個結果:
    • 停止 自動備份檔案上傳,或上傳最後的交易記錄檔案。監控 未處理的交易記錄備份大小,判斷資料庫移轉服務何時完成處理該檔案。
    • 您可以選擇上傳名稱結尾為 .trn.final 後置字串的交易記錄檔案。資料庫遷移服務偵測到備份檔案名稱符合 .trn.final 後置字串慣例時,就會停止持續載入。

      資料庫移轉服務處理該檔案後,移轉工作狀態會變更為「Ready to promote」

  3. 推送遷移工作
  4. (選用) 驗證遷移資料是否完整。