チュートリアル:Azure SQL Database と SQL Server のデータベース間の SQL データ同期を設定する

適用対象:Azure SQL Database

このチュートリアルでは、Azure SQL Database と SQL Server の両方のインスタンスを含む同期グループを作成することによって SQL データ同期を設定する方法について説明します。 同期グループはカスタム構成され、設定されたスケジュールで同期します。

このチュートリアルは、SQL Database と SQL Server の使用経験があることを前提としています。

SQL データ同期の概要については、SQL データ同期を使用したクラウドとオンプレミスのデータベース間でのデータの同期に関する記事を参照してください。

PowerShell を使用した SQL データ同期の構成方法の例については、SQL Database のデータベース間またはAzure SQL Database と SQL Server のデータベース間の同期方法に関する記事をご覧ください

重要

ハブ データベースは同期トポロジの中心になるエンドポイントであり、1 つの同期グループには複数のデータベース エンドポイントが含まれます。 同期グループ内にエンドポイントがある他のすべてのメンバー データベースが、ハブ データベースと同期します。

現在、SQL データ同期は、Azure SQL Database でのみサポートされています。 ハブ データベースは、Azure SQL Database にする必要があります。

Azure SQL データベース Hyperscale はハブデータベースとしてではなく、メンバーデータベースとしてのみサポートされています。

同期グループを作成する

  1. Azure portal に移動します。 SQL データベースを検索して選択し、既存の Azure SQL Database を見つけます。

  2. データ同期のハブ データベースとして使用するデータベースを選択します。

  3. 選択したデータベースの [SQL データベース] メニューの [データ管理]で、[別のデータベースに同期] を選択します。

  4. [別のデータベースに同期] ページで、 [新しい同期グループ] を選択します。 一緒に、[データ同期グループの作成] ページが開きます。

  5. [データ同期グループの作成] ページで、次の設定を構成します。

    A screenshot from the Create Data Sync page of the Azure portal, creating a new Sync Metadata Database to use with Automatic Sync.

    設定 説明
    同期グループ名 新しい同期グループの名前を入力します。 この名前は、データベース自体の名前とは異なります。
    同期メタデータ データベース 同期メタデータ データベースとして機能させるために、データベースの作成 (推奨)、あるいは既存データベースの使用を選択します。

    Microsoft では、同期メタデータ データベースとして使用する新しい空のデータベースを作成することをお勧めしています。 データ同期は、このデータベースにテーブルを作成し、頻繁に発生するワークロードを実行します。 このデータベースは、選択したリージョンとサブスクリプション内のすべての同期グループの同期メタデータ データベースとして共有されます。 リージョン内のすべての同期グループと同期エージェントを削除しないと、データベースまたはその名前を変更することはできません。

    新しいデータベースを作成する場合は、[新しいデータベース] を選択します。 [データベース設定を構成する]を選択する 次に、[SQL データベース] ページで、新しい Azure SQL データベースに名前を付けて構成し、[OK] を選択します。

    [既存のデータベースを使用する] を選択した場合は、[同期メタデータ データベース]ドロップダウン リストからデータベースを選択します。
    自動同期 [オン] または [オフ] を選択します。

    [オン] を選択した場合は、 [同期の頻度] セクションで数値を入力し、 [秒][分][時間] 、または [日] を選択します。
    最初の同期は、構成が保存されてから、指定した期間が経過した後に開始されます。
    競合の解決 [Hub win](ハブ優先) または [Member win](メンバー優先) を選択します。

    [Hub win](ハブ優先) とは、競合が発生した場合、ハブ データベースのデータによって、メンバー データベースの競合するデータが上書きされることを意味します。

    [Member win](メンバー優先) とは、競合が発生した場合、メンバー データベースのデータによって、ハブ データベースの競合するデータが上書きされることを意味します。
    [ハブ データベースのユーザー名][ハブ データベースのパスワード] ハブ データベースのサーバー管理者 SQL 認証済みログインにユーザー名とパスワードを入力します。 これは、起動したのと同じ Azure SQL 論理サーバーのサーバー管理者のユーザー名とパスワードです。 Microsoft Entra (旧 Azure Active Directory) 認証は現在サポートされていません。
    Private Link を使用する サービス マネージド プライベート エンドポイントを選択して、同期サービスとハブ データベースの間にセキュリティで保護された接続を確立します。
  6. [OK] を選択し、同期グループが作成されてデプロイされるまで待ちます。

  7. [新しい同期グループ] ページで、 [Use private link](Private Link を使用する) を選択した場合は、プライベート エンドポイント接続を承認する必要があります。 情報メッセージ内のリンクを使用すると、プライベート エンドポイント接続のエクスペリエンスに移動し、そこで接続を承認できます。

    A screenshot from the Azure portal Private Endpoint connections page, showing where to approve a private link.

    Note

    同期グループと同期メンバーのプライベート リンクは、個別に作成、承認、無効化する必要があります。

同期メンバーを追加する

新しい同期グループが作成およびデプロイされたら、同期グループを開き、 [データベース] ページにアクセスします。ここで、同期メンバーを選択します。

Note

ユーザー名とパスワードを更新するか、ハブ データベースに挿入するには、 [同期メンバーの選択] ページの [ハブ データベース] セクションに移動します。

Azure SQL Database のデータベースをメンバーとして同期グループに追加する

  1. [同期メンバーの選択] セクションで、必要に応じて [Azure データベースを追加] を選択して、Azure SQL Database 内のデータベースを同期グループに追加します。 [Azure データベースの構成] ページが開きます。

    A screenshot from the Azure portal of the Configure Azure Database page, where you can add a database to the sync group.

  2. [Configure Azure SQL Database](Azure SQL Database の構成) ページで、次の設定を変更します。

    設定 説明
    同期メンバー名 新しい同期メンバーの名前を指定します。 この名前は、データベース自体の名前とは異なります。
    サブスクリプション 課金のために関連付ける Azure サブスクリプションを選択します。
    Azure SQL Server 既存のサーバーを選択します。
    Azure SQL Database SQL Database 内の既存のデータベースを選択します。
    同期方向 同期の方向は、[ハブからメンバーへ] または [メンバーからハブへ]、あるいはその両方にすることができます。 [ハブから][ハブへ]、または [双方向同期] を選択します。詳細については、「しくみ」を参照してください。
    [ユーザー名][パスワード] メンバー データベースが配置されているサーバーの既存の資格情報を入力します。 このセクションでは、"新しい" 資格情報を入力しないでください。
    Private Link を使用する サービス マネージド プライベート エンドポイントを選択して、同期サービスとメンバー データベースの間にセキュリティで保護された接続を確立します。
  3. [OK] を選択し、新しい同期メンバーが作成され、デプロイされるまで待ちます。

SQL Server インスタンス上のデータベースをメンバーとして同期グループに追加する

  1. [メンバー データベース] セクションで、必要に応じて [オンプレミス データベースを追加] を選択して、SQL Server インスタンスのデータベースを同期グループに追加します。

  2. [オンプレミスの構成] ページが開き、次の操作を実行できます。

  3. [同期エージェント ゲートウェイの選択] を選択します。 [同期エージェントの選択] ページが開きます。

    A screenshot from the Azure portal, in the Configure On-Premises steps. When the Choose the Sync Agent Gateway option is selected, the Select Sync Agent page is shown.

  4. [同期エージェントの選択] ページで、既存のエージェントを使用するか、エージェントを作成するかを選択します。

    [既存のエージェント] を選択した場合は、一覧から既存のエージェントを選択します。

    [新しいエージェントの作成] を選択した場合は、次の操作を行います。

    1. 表示されているリンクからデータ同期エージェントをダウンロードし、SQL Server インスタンスが配置されているサーバーとは別のサーバーにインストールします。 このエージェントは、Azure SQL Data Sync Agent のページから直接ダウンロードすることもできます。 データ同期クライアント エージェントのベスト プラクティスについては、「Azure SQL データ同期のベスト プラクティス」をご覧ください。

      重要

      クライアント エージェントがサーバーと通信できるように、ファイアウォールの送信 TCP ポート 1433 を開く必要があります。

    2. [エージェント名] を入力する

    3. [Create and Generate Key](作成とキーの生成) を選択し、エージェント キーをクリップボードにコピーします。

    4. [OK] を選択して、 [同期エージェントの選択] ページを閉じます。

  5. 同期クライアントエージェントがインストールされているサーバーで、クライアント同期エージェントアプリを見つけて実行してください。

    A screenshot from the Microsoft SQL Data Sync 2.0 client agent app. The Submit Agent Key button is highlighted.

    1. 同期エージェント アプリで [Submit Agent Key](エージェント キーの送信) を選択します。 [Sync Metadata Database Configuration](同期メタデータ データベースの構成) ダイアログ ボックスが開きます。

    2. [Sync Metadata Database Configuration](同期メタデータ データベースの構成) ダイアログ ボックスで、Azure Portal からコピーしたエージェント キーを貼り付けます。 また、同期メタデータ データベース のデータベースが配置されているサーバーの既存の資格情報も適用します。 [OK] を選択し、構成が完了するまで待ちます。

      A screenshot from the Microsoft SQL Data Sync 2.0 client agent app. Enter the agent key and server credentials.

      Note

      ファイアウォール エラーが発生する場合は、SQL Server コンピューターからの受信トラフィックを許可するファイアウォール規則を Azure 上に作成する必要があります。 この規則は、ポータルまたは SQL Server Management Studio (SSMS) で手動で作成できます。 SSMS で、名前を <hub_database_name>.database.windows.net として入力することで、Azure 上のハブ データベースに接続します。

    3. [登録] を選択して、SQL Server データベースをエージェントに登録します。 [SQL Server の構成] ダイアログ ボックスが開きます。

      A screenshot from the Microsoft SQL Data Sync 2.0 client agent app. Add and configure a SQL Server database.

    4. [SQL Server の構成] ダイアログ ボックスで、SQL Server 認証と Windows 認証のどちらを使用して接続するかを選択します。 SQL Server 認証を選択した場合は、既存の資格情報を入力します。 SQL Server の名前と、同期するデータベースの名前を指定し、 [テスト接続] を選択して設定をテストします。 その後、 [保存] を選択します。登録したデータベースが一覧に表示されます。

      A screenshot from the Microsoft SQL Data Sync 2.0 application showing that the SQL Server database and machine are now registered.

    5. Client Sync Agent アプリを閉じます。

  6. Azure portal の [オンプレミスの構成] ページで、[データベースの選択] を選択します。

  7. [データベースの選択] ページの [メンバー名の同期] フィールドで、新しい同期メンバーの名前を指定します。 この名前は、データベース自体の名前とは異なります。 一覧からデータベースを選択します。 [同期方向] フィールドで、 [双方向の同期][ハブへ] 、または [ハブから] を選択します。

  8. [OK] を選択して、 [データベースの選択] ページを閉じます。 さらに [OK] を選択して [オンプレミスの構成] ページを閉じ、新しい同期メンバーが作成およびデプロイされるまで待ちます。 最後に、 [OK] を選択して [同期メンバーの選択] ページを閉じます。

Note

SQL データ同期およびローカル エージェントに接続するには、DataSync_Executor ロールにユーザー名を追加します。 データ同期は、このロールを SQL Server インスタンス上に作成します。

同期グループを構成する

新しい同期グループ メンバーが作成およびデプロイされたら、 [データベース同期グループ] ページの [テーブル] セクションに移動します。

A screenshot from the Azure portal, on the Tables page, select tables and fields to sync.

  1. [テーブル] ページで、同期グループ メンバーの一覧からデータベースを選択し、 [スキーマの更新] を選択します。 スキーマの更新には数分の遅延が生じることがあります。また、プライベート リンクを使用している場合は遅延時間が長くなる可能性があります。

  2. 一覧から、同期するテーブルを選択します。既定では、すべての列が選択されているため、同期しない列のチェック ボックスをオフにします。主キー列は、選択されたままにしておいてください。

  3. [保存] を選択します。

  4. 既定では、スケジュールに従うか手動で実行されるまで、データベースは同期されません。 手動による同期を実行するには、Azure portal で SQL Database 内の対象のデータベースに移動し、 [別のデータベースに同期] を選択し、同期グループを選択します。 [データ同期] ページが開きます。 [同期] を選択します。

    A screenshot from the Azure portal showing the manual sync button for a Database Sync Group.

よく寄せられる質問

このセクションでは、Azure SQL データ同期サービスに関するよくある質問に答えます。

SQL データ同期では、テーブル全体が作成されますか?

同期先データベースに同期スキーマ テーブルがない場合は、ご自分で選択した列を持つテーブルが SQL データ同期によって作成されます。 ただし、以下の理由から、これは完全に忠実なスキーマにはなりません。

  • 同期先テーブルには、ご自分で選択した列だけが作成されます。 選択していない列は無視されます。
  • 同期先テーブルには、選択した列のインデックスだけが作成されます。 列が選択されていない場合、それらのインデックスは無視されます。
  • XML 型の列のインデックスは作成されません。
  • CHECK 制約は作成されません。
  • 同期元テーブル上のトリガーは作成されません。
  • ビューとストアド プロシージャは作成されません。

これらの制限のため、次のことをお勧めします。

  • 運用環境では、完全に忠実なスキーマをご自身で作成します。
  • サービスを試す場合は、自動プロビジョニング機能を使用します。

自分で作成していないテーブルがあるのはなぜですか?

データ同期では、データベース内に変更を追跡するための追加のテーブルが作成されます。 これらを削除しないでください。削除するとデータ同期が動作を停止します。

同期後にデータは収束しますか?

必ずしもその必要はありません。 ハブと 3 つのスポーク (A、B、C) を持つ同期グループがあり、同期は ハブから A、ハブから B、ハブから C に対して行われるものとします。ハブから A への同期が実行された "" でデータベース A が変更された場合、その変更は、次の同期タスクが実行されるまで、データベース B またはデータベース C には書き込まれません。

スキーマの変更を同期グループに反映するにはどうすればよいですか?

すべてのスキーマの変更を手動で行い、手動で反映してください。

  1. ハブおよびすべての同期メンバーに対してスキーマ変更を手動でレプリケートします。
  2. 同期スキーマを更新します。

新しいテーブルと列を追加する場合:

新しいテーブルと列は現在の同期に影響しないため、データ同期では、それらが同期スキーマに追加されるまで無視されます。 新しいデータベース オブジェクトを追加する場合は、次のシーケンスに従ってください。

  1. 新しいテーブルまたは列を、ハブとすべての同期メンバーに追加します。
  2. 新しいテーブルまたは列を、同期スキーマに追加します。
  3. 新しいテーブルと列への値の挿入を開始します。

列のデータ型を変更するには、次のようにします。

既存の列のデータ型を変更した場合、データ同期は新しい値が同期スキーマで定義された元のデータ型に一致する限り動作を続行します。 たとえば、同期元データベース内の型を int から bigint に変更した場合、int データ型としては大きすぎる値を挿入するまで、データ同期は動作を続行します。 変更を完了するには、ハブとすべての同期メンバーに対してスキーマの変更を手動でレプリケートした後、同期スキーマを更新します。

データ同期でデータベースのエクスポートとインポートを行うにはどうすればよいですか?

データベースを .bacpac ファイルとしてエクスポートし、そのファイルをインポートしてデータベースを作成した後、以下を実行して、新しいデータベースでデータ同期を使用します。

  1. Data Sync complete cleanup.sql を使用して、新しいデータベースでデータ同期オブジェクトと追加のテーブルをクリーンアップします。 このスクリプトは、データベースからすべての必要なデータ同期オブジェクトを削除します。
  2. 新しいデータベースで同期グループを再作成します。 古い同期グループが必要ない場合は削除します。

クライアント エージェントに関する情報はどこで見つけることができますか?

クライアント エージェントについてよく寄せられる質問については、エージェントに関する FAQ のセクションを参照してください。

リンクは、使用を開始する前に手動で承認する必要がありますか?

はい。 同期グループのデプロイ中に Azure portal の [プライベート エンドポイント接続] ページで、または PowerShell を使用して、サービス マネージド プライベート エンドポイントを手動で承認する必要があります。

同期ジョブによって Azure データベースがプロビジョニングされているときにファイアウォール エラーが発生するのはなぜですか?

これは、Azure リソースにサーバーへのアクセスが許可されていないことが原因で発生する可能性があります。 以下に示す 2 つのソリューションがあります。

  1. Azure データベースのファイアウォールで [Azure サービスおよびリソースにこのサーバーへのアクセスを許可する][はい] に設定されていることを確実にします。 詳細については、Azure SQL Database およびネットワーク アクセスの制御に関するページを参照してください。
  2. データ同期のプライベート リンクを構成します。これは、Azure Private Link とは異なります。 Private Link は、ファイアウォールの背後にあるデータベースとのセキュリティで保護された接続を使用して同期グループを作成する方法です。 SQL データ同期 Private Link は Microsoft マネージド エンドポイントであり、既存の仮想ネットワーク内にサブネットを内部的に作成するため、別の仮想ネットワークやサブネットを作成する必要はありません。

次のステップ

お疲れさまでした。 Azure SQL データベースと SQL Server データベースの両方を含む同期グループを作成しました。

SQL データ同期の詳細については、以下を参照してください。

SQL Database の詳細については、以下を参照してください。