Always On 可用性グループ内のレプリカに対するクライアント接続の種類

適用対象:SQL Server

AlwaysOn 可用性グループでは、1 つまたは複数の可用性レプリカを構成して、セカンダリ ロールで実行しているとき (つまり、セカンダリ レプリカとして実行しているとき) に読み取り専用接続を許可することができます。 各可用性レプリカをプライマリ ロールで実行しているとき (つまり、プライマリ レプリカとして実行しているとき) に、読み取り専用接続を許可または除外するように構成することもできます。

特定の可用性グループのプライマリ データベースまたはセカンダリ データベースに対するクライアント アクセスを容易にするために、可用性グループ リスナーを定義する必要があります。 既定では、可用性グループ リスナーは、着信接続をプライマリ レプリカにダイレクトします。 ただし、可用性グループは、読み取り専用ルーティングをサポートするように構成できます。これにより、可用性グループ リスナーが、読み取りを目的としたアプリケーションの接続要求を読み取り可能なセカンダリ レプリカにリダイレクトできます。 詳細については、可用性グループの読み取り専用ルーティングの構成 (SQL Server) に関する記事を参照してください

フェールオーバー中に、セカンダリ レプリカはプライマリ ロールに移行し、元のプライマリ レプリカはセカンダリ レプリカに移行します。 フェールオーバー プロセス中に、プライマリ レプリカとセカンダリ レプリカの両方に対するクライアント接続がすべて終了されます。 フェールオーバー後にクライアントが可用性グループ リスナーに再接続すると、リスナーは、クライアントを新しいプライマリ レプリカに再接続します。ただし、読み取りを目的とした接続要求は除きます。 クライアントとサーバーのインスタンスと、少なくとも 1 つの読み取り可能なセカンダリ レプリカで、新しいプライマリ レプリカをホストする読み取り専用ルーティングが構成された場合、読み取りを目的とした接続要求は、クライアントが必要とするタイプの接続アクセスをサポートするセカンダリ レプリカに再ルーティングされます。 フェールオーバー後にクライアントが快適にサービスを利用できるように、すべての可用性レプリカのセカンダリ ロールとプライマリ ロールに対して接続アクセスを構成することが重要です。

Note

クライアント接続要求を処理する可用性グループ リスナーの詳細については、「可用性グループ リスナー、クライアント接続、およびアプリケーションのフェールオーバー (SQL Server)」をご参照ください。

セカンダリ ロールでサポートされる接続アクセスの種類

セカンダリ ロールは、次に示すように 3 種類のクライアント接続をサポートします。

接続不可
ユーザーの接続は許可されません。 セカンダリ データベースは読み取りアクセスでは利用できません。 これは、セカンダリ ロールの既定の動作です。

読み取りを目的とした接続のみ
セカンダリ データベースは、 アプリケーションの目的 接続プロパティが ReadOnly (読み取り目的の接続) に設定されている接続に対してのみ利用できます。

この接続プロパティの詳細については、「 SQL Server Native Client の HADR サポート」を参照してください。

読み取り専用接続を許可
セカンダリ データベースは、すべて読み取りアクセス接続に利用できます。 このオプションでは、下位バージョンのクライアントを接続できます。

詳細については、可用性レプリカへの読み取り専用アクセスの構成 (SQL Server) に関するページを参照してください。

プライマリ ロールでサポートされる接続アクセスの種類

プライマリ ロールは、次に示すように 2 種類のクライアント接続をサポートします。

すべての接続を許可する
プライマリ データベースに対する読み取り/書き込み接続と読み取り専用接続の両方が許可されます。 これは、プライマリ ロールの既定の動作です。

読み取り/書き込接続のみを許可する
アプリケーションの目的 接続プロパティが ReadWrite に設定されるか、または値が設定されていない場合、接続が許可されます。 Application Intent 接続文字列キーワードが ReadOnly に設定されている接続は許可されません。 読み取り/書き込み接続のみを許可することにより、読み取りを目的としたワークロードが誤ってプライマリ レプリカに接続されるのを防ぐことができます。

この接続プロパティの詳細については、「 Using Connection String Keywords with SQL Server Native Client」を参照してください。

詳細については、可用性レプリカへの読み取り専用アクセスの構成 (SQL Server) に関するページを参照してください。

接続アクセス構成がクライアント接続に与える影響

レプリカの接続アクセス設定によって、接続試行が失敗するか成功するかが決まります。 次の表に、特定の接続試行が成功するか失敗するかを接続アクセス設定別に示します。

レプリカのロール レプリカでサポートされる接続アクセス 接続の目的 接続の試行の結果
セカンダリ すべて 読み取り目的、読み取り/書き込み、または接続目的の指定なし 成功
セカンダリ なし (これは、セカンダリの既定の動作です)。 読み取り目的、読み取り/書き込み、または接続目的の指定なし 障害
セカンダリ [読み取り目的のみ] 読み取り目的 成功
セカンダリ [読み取り目的のみ] 読み取り/書き込み、または接続目的の指定なし 障害
プライマリ すべて (これはプライマリの既定の動作です) 読み取りのみ、読み取り/書き込み、または接続目的の指定なし 成功
プライマリ 読み取り/書き込み [読み取り目的のみ] 障害
プライマリ 読み取り/書き込み 読み取り/書き込み、または接続目的の指定なし 成功

可用性グループを構成してそのレプリカへのクライアント接続を受け入れることに関する情報については、「可用性グループ リスナー、クライアント接続、およびアプリケーションのフェールオーバー (SQL Server)」をご参照ください。

接続のアクセス構成の例

可用性レプリカの接続アクセスの構成内容がそれぞれ異なっている場合、可用性グループがフェールオーバーした後でクライアント接続のサポートが変わる可能性があります。 たとえば、リモートの非同期コミット セカンダリ レプリカでレポートが実行された可用性グループについて考えてみましょう。 この可用性グループのデータベースのすべての読み取り専用アプリケーションで、 アプリケーションの目的 接続プロパティが ReadOnlyに設定されているため、すべての読み取り専用接続が読み取りを目的とした接続です。

この例の可用性グループには、メインのコンピューティング センターにある 2 つの同期コミット レプリカと、サテライト サイトにある 2 つの非同期コミット レプリカが含まれています。 プライマリ ロールに対しては、すべてのレプリカに読み取り/書き込みアクセスが構成され、どのような状況でもプライマリ レプリカへの読み取りを目的とした接続ができないようになっています。 同期コミットのセカンダリ ロールでは、既定の接続アクセス構成 ("なし") が使用されるため、セカンダリ ロールではすべてのクライアント接続が禁止されます。 一方、非同期コミット レプリカは、セカンダリ ロールでの読み取り目的の接続を許可するように構成されています。 次の表に、この例の構成をまとめます。

[レプリカ] コミット モード [初期ロール] セカンダリ ロールの接続アクセス プライマリ ロールの接続アクセス
Replica1 Synchronous プライマリ None 読み取り/書き込み
Replica2 Synchronous セカンダリ None 読み取り/書き込み
Replica3 非同期 セカンダリ 読み取り目的のみ 読み取り/書き込み
Replica4 非同期 セカンダリ [読み取り目的のみ] 読み取り/書き込み

一般的に、この例のシナリオでは、フェールオーバーは同期コミット レプリカ間でのみ実行され、フェールオーバーの直後に、読み取り目的のアプリケーションが非同期コミット セカンダリ レプリカの 1 つに再接続できます。 ただし、メインのコンピューティング センターで障害が発生した場合は両方の同期コミット レプリカが失われます。 サテライト サイトのデータベース管理者が、非同期コミット セカンダリ レプリカへの強制フェールオーバーを手動で実行して対処します。 残りのセカンダリ レプリカのセカンダリ データベースは強制フェールオーバーによって中断されるため、読み取り専用のワークロードで使用できなくなります。 読み取り/書き込み接続が構成されている新しいプライマリ レプリカでは、読み取り目的のワークロードと読み取り/書き込みワークロードが競合しません。 つまり、データベース管理者が残りの非同期コミット セカンダリ レプリカのセカンダリ データベースを再開するまでは、読み取り目的のクライアントはどの可用性レプリカにも接続できません。

Related Tasks

関連コンテンツ

参照

Always On 可用性グループの概要 (SQL Server)
可用性グループ リスナー、クライアント接続、およびアプリケーションのフェールオーバー (SQL Server)
統計