Cloud SQL for SQL Server インスタンスから移行する

このページでは、Database Migration Service を使用して Cloud SQL for SQL Server データベースを Cloud SQL for SQL Server インスタンスに移行する方法について説明します。この移行フローを使用すると、同じプロジェクトまたは別のプロジェクトの別の Cloud SQL for SQL Server にデータベースを移行できます。 Google Cloud セルフマネージド ソースまたは Amazon RDS ソースから移行する手順については、 セルフホスト ソースと Amazon RDS ソースの移行ガイドをご覧ください。

Cloud SQL for SQL Server ソースの移行プロセスには、次のタスクが含まれます。

  1. Database Migration Service がバックアップ ファイルを Cloud Storage バケットに自動的にエクスポートできるように、ソースの Cloud SQL for SQL Server インスタンスを構成する。

  2. Google Cloud CLI を使用して移行元接続プロファイルを作成する。

  3. 移行先の Cloud SQL for SQL Server インスタンスを作成する。

  4. Google Cloud CLI を使用して Database Migration Service で移行ジョブを作成し、実行します。

  5. Database Migration Service のオブザーバビリティ機能を使用して移行ジョブの進行状況をモニタリングする。

  6. データが完全に移行された後、移行ジョブをプロモートします。

費用

Cloud SQL への同種移行の場合、Database Migration Service は追加料金なしで利用できます。ただし、移行用に作成された Cloud SQL エンティティと Cloud Storage エンティティだけでなく、ネットワーク料金にも Cloud SQL と Cloud Storage の料金が適用されます。

このドキュメントでは、課金対象である次のGoogle Cloudコンポーネントを使用します。

  • Cloud Storage
  • Cloud SQL

料金計算ツールを使うと、予想使用量に基づいて費用の見積もりを生成できます。

始める前に

  1. この移行パスでシナリオを完全にサポートできるかどうかを確認します。SQL Server の既知の制限事項をご覧ください。
  2. 宛先データベースを作成するリージョンを検討します。Database Migration Service は完全にリージョンに依存するプロダクトです。つまり、移行に関連するすべてのエンティティ(移行元と移行先の接続プロファイル、移行ジョブ、移行先データベース、ストレージ バケット)は、単一のリージョンに保存する必要があります。
  3. Google Cloud コンソールのプロジェクト セレクタ ページで、 Google Cloud プロジェクトを選択または 作成します。

    プロジェクト セレクタに移動

  4. Database Migration Service、Compute Engine、Cloud Storage、Cloud SQL Admin API を有効にします。

    API を有効にする

必要なロール

Database Migration Service を使用して 2 つの Cloud SQL for SQL Server インスタンス間で同種移行を実行するために必要な権限を取得するには、関連するプロジェクトで、 移行プロセスに関与するアカウントに必要な IAM ロールを付与するよう管理者に依頼してください。

このシナリオでは、異なる Google Cloud プロジェクトにある 2 つの Cloud SQL for SQL Server インスタンス間で移行できます。同じプロジェクト内のインスタンス間で移行する場合は、同じプロジェクト内のすべての権限を付与します。ロールの付与の詳細については、 アクセス権の管理をご覧ください。

移行元プロジェクトのロールと権限

移行元の Cloud SQL for SQL Server インスタンスが存在する Google Cloud プロジェクトの特定のアカウントに、次のロールを付与します。

これらの事前定義ロールには、Database Migration Service を使用して同種 SQL Server 移行を実行するために必要な権限が含まれています。必要とされる正確な権限については、「必要な権限(ソース プロジェクト)」セクションを開いてご確認ください。

必要な権限(ソース プロジェクト)

Database Migration Service を使用して同種 SQL Server 移行を実行するには、次の権限が必要です。

  • 移行を実行するユーザー アカウント:
    • 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
  • 宛先プロジェクトの Database Migration Service サービス アカウント:
    • cloudsql.instances.export
    • cloudsql.instances.get
    • cloudsql.instances.list
    • cloudsql.instances.executeSql

カスタムロールや他の 事前定義ロールを使用して、これらの権限を取得することもできます。

移行先プロジェクトのロールと権限

移行先の Cloud SQL for SQL Server インスタンスが存在する Google Cloud プロジェクトの特定のアカウントに、次のロールを付与します。

これらの事前定義ロールには、Database Migration Service を使用して同種 SQL Server 移行を実行するために必要な権限が含まれています。必要とされる正確な権限については、「必要な権限(宛先プロジェクト)」セクションを開いてご確認ください。

必要な権限(宛先プロジェクト)

Database Migration Service を使用して同種 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
  • Database Migration Service サービス アカウント:
    • 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
  • ソース インスタンスに関連付けられた Cloud SQL サービス アカウント:
    • storage.objects.create
    • storage.objects.list
    • storage.objects.get

カスタムロールや他の 事前定義ロールを使用して、これらの権限を取得することもできます。

移行元の Cloud SQL インスタンスを準備する

  1. 宛先 Google Cloud プロジェクトに Cloud Storage バケットを作成します。このバケットは、ソースの Cloud SQL for SQL Server インスタンスからエクスポートされたバックアップ ログファイルの保存に使用されます。

    • これらのバックアップ ファイルのデータ保持期間は 1430 日に設定することをおすすめします。
    • ソース インスタンスに関連付けられている Cloud SQL サービス アカウントには、このバケットにバックアップ ファイルを書き込むための Storage オブジェクト ユーザーroles/storage.objectUser)IAM ロールが必要です。この移行フローの権限の詳細については、 必要なロールのセクションをご覧ください。
  2. 移行元 Cloud SQL for SQL Server インスタンスを構成します

  3. Cloud SQL for SQL Server 移行元インスタンスの 移行元接続プロファイルを作成します。

Cloud SQL for SQL Server の移行先インスタンスを準備する

移行先の Cloud SQL インスタンスを構成するには、次の操作を行います。

  1. Cloud SQL for SQL Server の移行先インスタンスを作成して構成します。移行のニーズを満たすのに十分なコンピューティング リソースとメモリリソースを使用していることを確認します。

  2. Cloud SQL インスタンスの 移行先接続プロファイルを作成します。

移行ジョブを作成して実行する

  1. Cloud SQL for SQL Server ソースの移行ジョブを作成して実行します

移行ジョブを開始すると、移行先の Cloud SQL for SQL Server データベースが復元モードになり、Database Migration Service によって完全に管理されます。データが完全に移行されたら、移行先インスタンスをプロモートできます。移行先インスタンスがプロモートされると、そのインスタンス内のすべてのデータベースが完全に動作するようになります。これらのデータベースに対する完全な書き込みアクセス権も付与されます。

移行を完了する

アプリケーションを新しい Cloud SQL for SQL Server インスタンスに切り替える場合は、次の手順で移行を完了します。

  1. 移行元データベースに対するすべての書き込みオペレーションを停止します。読み取り専用モードに切り替えて、運用機能を維持できます。
  2. 移行ジョブをプロモートします
  3. (省略可) 移行データの完全性を確認します。