レプリケーションの全般的パフォーマンスの向上
適用対象: SQL Server Azure SQL Managed Instance
このトピックで解説するガイドラインに従うことによって、アプリケーションおよびネットワーク上にある全種類のレプリケーションの全般的なパフォーマンスを向上させることができます。
サーバーおよびネットワーク
Microsoft SQL Server データベース エンジンに割り当てるメモリの最大容量と最小容量を設定します。
既定では、データベース エンジンは使用できるシステム リソースに基づいて、そのメモリ要求を動的に変更します。 レプリケーション作業中に使用できるメモリ容量が少なくなるのを防ぐには、 min server memory オプションを使用して最小メモリ容量を設定します。 オペレーティング システムによるディスクへのメモリ書き出しを防ぐために、 max server memory オプションを使用して最大メモリ容量を設定することもできます。 詳細については、「サーバー メモリに関するサーバー構成オプション」を参照してください。
データベースのデータ ファイルおよびログ ファイルを適切に配置する。 レプリケーションに関係するすべてのデータベースのトランザクション ログを、別のディスク ドライブに格納します。
データベースの格納に使用するものとは別のディスク ドライブにログ ファイルを保存することで、トランザクションの書き込みにかかる時間を節約できます。 フォールト トレランスが必要な場合は、Redundant Array of Inexpensive Disks (RAID)-1 を使用して、そのドライブをミラー化できます。 他のデータベース ファイルには RAID 0 または 0+1 (フォールト トレランスの必要性によって異なります) を使用してください。 これは、レプリケーションを使用するかどうかとは無関係に、良い方法です。
レプリケーションで使用するサーバー、特にディストリビューターにメモリを追加する。
マルチプロセッサ コンピューターを使用する。
レプリケーション エージェントはサーバー上の追加プロセッサを利用できます。 実行時の CPU 使用量が高いレベルにある場合、より高速の CPU または複数の CPU のインストールを検討してください。
高速ネットワークを使用する。
特にトランザクション レプリケーションでは、ネットワークがパフォーマンスの重大なボトルネックになる場合があります。 サブスクライバーへの変更の反映は、100 メガバイト/秒 (Mbps) 以上の高速ネットワークを使用することで大幅に高速化されます。 ネットワークが低速な場合は、適切なネットワーク設定とエージェント パラメーターを指定してください。
データベースの設計
データベース設計の推奨事項に従う。
レプリケートされたデータベースにおけるパフォーマンス最適化の手順は、レプリケートされていないデータベースの場合と同じです。 ただし、サブスクライバーでインデックスを作成する場合は注意が必要です。サブスクライバーの主キー列にはインデックスを作成しますが、その他の列にインデックスを作成すると、挿入、更新、および削除処理のパフォーマンスに影響する場合があります。
READ_COMMITTED_SNAPSHOT データベース オプションを設定する。
ユーザーの処理とレプリケーション エージェントの処理との競合を削減するには、パブリケーションおよびサブスクリプション データベースに対してこのオプションを設定します。
ALTER DATABASE AdventureWorks SET READ_COMMITTED_SNAPSHOT ON
詳しくは、「 ALTER DATABASE (Transact-SQL)」をご覧ください。
トリガーのアプリケーション ロジックに注意する。
サブスクライバーのユーザー定義トリガー内のビジネス ロジックによって、サブスクライバーへの変更のレプリケーション速度が低下する可能性があります。
トランザクション レプリケーションでは、レプリケートされたコマンドの適用に使用されるカスタム ストアド プロシージャにこのようなロジックを含める方がより効率的です。 詳細については、「トランザクション アーティクルに変更を反映する方法の指定」を参照してください。
マージ レプリケーションの場合には、ビジネス ロジック ハンドラーを使用する方がより効率的です。 詳細については、「Execute Business Logic During Merge Synchronization」(マージ同期中のビジネス ロジックの実行) をご覧ください。
マージ レプリケーションにパブリッシュされるテーブルの参照整合性を維持する目的でトリガーを使用する場合は、テーブルの処理順序を指定してマージ エージェントが必要とする再試行の回数を削減します。 詳細については、マージ レプリケーションのオプションの指定に関するページを参照してください。
Large Object (LOB) データ型の使用を制限する。
列の他のデータ型と比較して、LOB はより大きな記憶域とより多くの処理を必要とします。 アプリケーションで必要でない限り、LOB 型の列をアーティクルに含めないようにしてください。 text、 ntext、および image の各データ型は非推奨とされます。 LOB が必要な場合は、 varchar(max)、 nvarchar(max)、および varbinary(max)の各データ型を使用することをお勧めします。
トランザクション レプリケーションの場合は、 OLEDB ストリームのディストリビューション プロファイルと呼ばれるディストリビューション エージェント プロファイルの使用を検討してください。 詳しくは、「 レプリケーション エージェント プロファイル」をご覧ください。
パブリケーションの設計
必要なデータのみをパブリッシュする。
レプリケーションは簡単にセットアップできるので、実際に必要なデータ以外もパブリッシュされる傾向があります。 これによって、ディストリビューション データベースとスナップショット ファイル内でリソースが余計に消費され、必要なデータに対するスループットが低下する恐れがあります。 不要なテーブルのパブリッシュを避け、パブリケーションの更新頻度を低くすることを検討してください。
パブリケーションの設計とアプリケーションの動作により競合を最小化する。
マージ レプリケーション、更新可能なサブスクリプションを使用したトランザクション レプリケーション、およびピア ツー ピア トランザクション レプリケーションでは、サブスクライバーでデータを変更できます。 マージ レプリケーションおよび更新可能なサブスクリプションを使用したトランザクション レプリケーションは、指定した行が同期中に複数のノードで更新された場合のデータの競合をサポートしています。 ピア ツー ピア トランザクション レプリケーションはデータの競合をサポートしていません。データの変更はパーティション分割されます。 使用するレプリケーションの種類にかかわらず、できる限りデータの変更をパーティション分割することをお勧めします。これにより、競合の検出と解決に必要な処理を減らすことができます。
変更をパーティション分割するには、各サブスクライバーにデータのサブセットをパブリッシュするか、またはアプリケーションを使用して、指定した行の変更を所定のノードに転送します。
マージ レプリケーションは、単一パブリケーションで、パラメーター化されたフィルターを使用したデータのサブセットのパブリッシュをサポートしています。 詳しくは、「 Parameterized Row Filters」をご覧ください。
トランザクション レプリケーションは、複数のパブリケーションで、静的フィルターを使用したデータのサブセットのパブリッシュをサポートしています。 詳細については、「パブリッシュされたデータのフィルター選択」を参照してください。
行フィルターの使用は慎重に行う。
トランザクション パブリケーションに行フィルターを使用したアーティクルが 1 つ以上格納されている場合、ログ リーダー エージェントはトランザクション ログをスキャンする際に、テーブルの更新の影響を受ける各行にフィルターを適用する必要があります。 このため、ログ リーダー エージェントのスループットが影響を受けます。
同様に、マージ レプリケーションは、変更または削除された行を評価して、これらの行をどのサブスクライバーが受け取るかを決定する必要があります。 サブスクライバーで要求されるデータを減らすために行フィルターを使用する場合、この処理はテーブルのすべての行をパブリッシュする場合よりも複雑になり、速度が低下する可能性があります。 各サブスクライバーに必要な記憶域の削減と、最高スループット達成の間でのトレードオフを慎重に検討してください。 フィルター選択の詳細については、「パブリッシュされたデータのフィルター選択」を参照してください。
サブスクリプションに関する注意点
サブスクライバーの数が多い場合はプル サブスクリプションを使用する。
ディストリビューション エージェントとマージ エージェントは、プッシュ サブスクリプションの場合はディストリビューター側で、プル サブスクリプションの場合はサブスクライバー側で実行されます。 プル サブスクリプションを使用して、エージェントの処理をディストリビューターからサブスクライバーに移動すると、パフォーマンスを向上させることができます。 詳細については、「パブリケーションのサブスクライブ」をご覧ください。
サブスクライバーの処理が遅すぎる場合はサブスクリプションを再初期化する。
大量の変更をサブスクライバーに送信する必要があるときには、サブスクライバーを新しいスナップショットで再初期化する方が、レプリケーションを使用して個々の変更を移動するよりも高速な場合があります。 詳細については、「 サブスクリプションの再初期化」を参照してください。
トランザクション レプリケーションの場合は、レプリケーション モニターの [未配布のコマンド] タブに、サブスクライバーにまだ配布されていないディストリビューション データベース内のトランザクションの数と、これらのトランザクションの予測配布時間が表示されます。 詳細については、「View information and perform tasks using Replication Monitor」 (レプリケーション モニターを使用して情報を表示し、タスクを実行する) を参照してください。
スナップショットに関する注意点
必要に応じて、データベースの利用状況が少ないときにのみスナップショット エージェントを実行する。
スナップショット エージェントは、パブリッシャーでパブリッシュされたテーブルから、ディストリビューターのスナップショット フォルダーにあるファイルにデータを一括コピーします。 スナップショットの生成には大量のリソースが必要となる場合があるため、利用状況が少ないときにスケジュールするのが最適です。
キャラクター モードのスナップショットが必要ない場合は、ネイティブ モードのスナップショットを使用する。
すべてのサブスクライバーに対して既定のネイティブ モードのスナップショットを使用します。ただし、SQL Server 以外のサブスクライバーと SQL Server Compact を実行しているサブスクライバーは除きます。これらのサブスクライバーでは、文字モードのスナップショットを使用する必要があります。
パブリケーションごとに単一のスナップショット フォルダーを使用する。
スナップショットの場所に関係するパブリケーション プロパティを指定するときには、既定のスナップショット フォルダーにスナップショット ファイルを生成するか、別のスナップショット フォルダーに生成するか、またはその両方を選択できます。 両方の場所にスナップショット ファイルを生成する場合は、スナップショット エージェントを実行するときに追加のディスク領域と処理が必要になります。
データベースまたはログ ファイルの格納に使用しないディストリビューターのローカル ドライブにスナップショット フォルダーを配置する。
スナップショット エージェントは、スナップショット フォルダーに対してデータの順次書き込みを実行します。 データベースやログ ファイルとは別のドライブにスナップショット フォルダーを配置することによって、ディスク間の競合が減少し、スナップショット処理がより高速に実行されます。
サブスクライバーにサブスクリプション データベースを作成する場合は、単純復旧モデルまたは一括ログ復旧モデルを指定する。 これによって、サブスクライバーでのスナップショットの適用中に実行される一括挿入のログを最小限に抑えることができます。 スナップショットがサブスクリプション データベースに適用されたら、必要に応じて別の復旧モデルに変更できます (レプリケートされたデータベースでは、すべての復旧モデルを使用できます)。 復旧モデルの選択の詳細については、「復元と回復の概要 (SQL Server)」を参照してください。
低帯域ネットワークでは、リムーバブル メディア上での代替スナップショット フォルダーおよび圧縮スナップショットを使用する。
代替スナップショット フォルダーに圧縮スナップショット ファイルを格納することにより、スナップショットに必要なディスク領域を節約して、スナップショット ファイルをリムーバブル メディアに容易に移動できるようになります。
圧縮スナップショットを使用すると、ネットワーク経由でスナップショット ファイルを移動する際のパフォーマンスが向上する場合があります。 ただし、スナップショットを圧縮すると、スナップショット ファイル生成時のスナップショット エージェント、およびスナップショット ファイル適用時のディストリビューション エージェントまたはマージ エージェントで、追加の処理が必要になります。 これにより、スナップショット生成が遅くなり、スナップショットを適用するための時間が延びることもあります。 また、ネットワークに障害が発生した場合、圧縮スナップショットを復旧することはできません。したがって、信頼性の低いネットワークには向いていません。 ネットワーク経由で圧縮スナップショットを使用するときは、これらのトレードオフを慎重に検討してください。 詳細については、スナップショット オプションの変更に関する記事を参照してください。
サブスクリプションを手作業で初期化する。
巨大な初期データセットを扱うようなシナリオでは、スナップショット以外の方法を使用して、サブスクリプションを初期化することをお勧めします。 詳細については、「 スナップショットを使用しないトランザクション サブスクリプションの初期化を使用して、サブスクリプションを手動で初期化する方法について説明します。
エージェント パラメーター
初期テスト、監視、またはデバッグの間を除いて、レプリケーション エージェントの冗長レベルを低く設定する。
ディストリビューション エージェントまたはマージ エージェントの –HistoryVerboseLevel パラメーターおよび –OutputVerboseLevel パラメーターを低く設定します。 これにより、エージェントの履歴および出力を追跡するために挿入される新しい行の数を減らすことができます。 代わりに、同じ状態の既存の履歴メッセージが、新しい履歴情報に更新されます。 テスト、監視、およびデバッグを行うときには、冗長レベルを高く設定して、エージェントの動作に関する情報をできるだけ多く得られるようにしてください。
スナップショット エージェント、マージ エージェント、およびディストリビューション エージェントの –MaxBCPThreads パラメーターを使用します (コンピューターのプロセッサ数を超えるスレッド数は指定できません)。 このパラメーターには、スナップショットの作成および適用時に並列実行できる一括コピーの操作数を指定します。
ディストリビューション エージェントおよびマージ エージェントの –UseInprocLoader パラメーターを使用します (パブリッシュされたテーブルに XML 列が含まれる場合、このパラメーターは使用できません)。 このパラメーターを指定すると、スナップショットの適用時にエージェントが BULK INSERT コマンドを実行します。
エージェント パラメーターは、エージェント プロファイルおよびコマンド ラインで指定できます。 詳細については、以下を参照してください: