次の方法で共有


Always On 可用性グループのリスナーの構成

適用対象: SQL Server

このトピックでは、SQL Server で SQL Server Management Studio、Transact-SQL、または PowerShell を使用して、Always On 可用性グループに対して 1 つの 可用性グループ リスナー を作成または構成する方法についての説明をします。

重要

可用性グループの最初の可用性グループ リスナーを作成するには、SQL Server Management Studio、Transact-SQL、または SQL Server PowerShell を使用することを強くお勧めします。 必要な場合 (追加リスナーを作成する場合など) を除いて、WSFC クラスターでリスナーを直接作成することは避けてください。

この可用性グループに既にリスナーが存在しますか?

可用性グループにリスナーが既に存在するかどうかを確認するには

Note

リスナーが既に存在するときに追加リスナーを作成する場合、このトピックの後半の「可用性グループの追加のリスナーを作成するには」を参照してください。

制限事項と制約事項

  • SQL Serverで、可用性グループに対して作成できるリスナーは 1 つのみです。 通常、それぞれの可用性グループで必要なリスナーは 1 つだけです。 ただし、一部の顧客シナリオでは、1 つの可用性グループで複数のリスナーが必要です。 SQL Server で 1 つのリスナーを作成した後、フェールオーバー クラスターの Windows PowerShell または WSFC フェールオーバー クラスター マネージャーを使用して、追加のリスナーを作成します。 詳細については、このトピックの後半の「可用性グループの追加のリスナーを作成するには」を参照してください。

推奨事項

複数のサブネットを構成する場合は、必須ではありませんが、静的 IP アドレスの使用をお勧めします。

前提条件

  • プライマリ レプリカをホストするサーバー インスタンスに接続されている必要があります。

  • 複数のサブネットにまたがって可用性グループのリスナーを設定し、静的 IP アドレスを使用する場合は、リスナーを作成する可用性グループの可用性レプリカをホストするすべてのサブネットの静的 IP アドレスを取得する必要があります。 通常は、静的 IP アドレスをネットワーク管理者に問い合わせることが必要です。

重要

初めてリスナーを作成する前に、Always On クライアント接続 に関するページをご覧いただくことを強くお勧めします。

可用性グループ リスナーの DNS 名の要件

各可用性グループ リスナーは、ドメインおよび NetBIOS 内で一意の DNS ホスト名を必要とします。 DNS 名は、文字列値です。 この名前には、英数字、ダッシュ/ハイフン (-)、およびアンダースコア (_) のみを任意の順序で含めることができます。 DNS ホスト名では大文字と小文字は区別されません。 最大長は 63 文字です。ただし、 SQL Server Management Studioで指定できる最大長は 15 文字です。

意味のある文字列を指定することをお勧めします。 たとえば、可用性グループの名前が AG1の場合は、 ag1-listenerのような意味のある DNS ホスト名にします。

重要

NetBIOS では、dns_name の最初の 15 文字のみが認識されます。 同じ Active Directory で制御されている 2 つの WSFC クラスターがあり、両方のクラスターで可用性グループ リスナーを作成しようとする場合、15 文字より長い名前を使用して、15 文字のプレフィックスが同一であると、仮想ネットワーク名リソースをオンラインにできなかったことを示すエラーが表示されます。 DNS 名のプレフィックスに対する名前付け規則の詳細については、「ドメイン名を割り当てる」を参照してください。

Windows アクセス許可

アクセス許可 Link
可用性グループをホストしている WSFC クラスターのクラスター名オブジェクト (CNO) には、Create Computer objects アクセス許可が必要です。

Active Directory では、CNO は既定でコンピュータオブジェクトの作成のアクセス許可を明示的に持たず、仮想コンピューター オブジェクト (VCO) を最大で 10 個作成できます。 VCO を 10 個作成した後、追加で VCO を作成しようとしても失敗します。 この問題は、WSFC クラスターの CNO に権限を明示的に与えることで回避できます。 削除した可用性グループのVCOは、手動で削除しない限り、Active Directory で自動的に削除されず、10 VCO の既定の制限に対してカウントされます。
注: 組織によっては、 Create Computer objects 権限を個別のユーザー アカウントに付与することがセキュリティ ポリシーで禁止されている場合があります。
クラスターをインストールするユーザーのアカウントを構成する手順:フェールオーバー クラスター ステップ バイ ステップ ガイド: Active Directory のアカウントの構成
クラスター名アカウントを事前設定する手順:フェールオーバー クラスター ステップ バイ ステップ ガイド: Active Directory のアカウントの構成
リスナーの仮想ネットワーク名にコンピューター アカウントを事前設定する必要がある場合には、Account Operator グループのメンバーシップが必要です。または、ドメイン管理者に依頼する必要があります。 クラスター化されたサービスまたはアプリケーションのアカウントを事前設定する手順:フェールオーバー クラスター ステップ バイ ステップ ガイド: Active Directory のアカウントの構成

ヒント

一般的には、リスナーの仮想ネットワーク名にコンピューター アカウントを事前設定しないことが最も簡単です。 可能な場合は、WSFC の高可用性ウィザードを実行する際にアカウントが自動的に作成および構成されるように構成します。

SQL Server 権限

タスク アクセス許可
可用性グループ リスナーを作成するには sysadmin 固定サーバー ロールのメンバーシップと、CREATE AVAILABILITY GROUP サーバー権限、ALTER ANY AVAILABILITY GROUP 権限、CONTROL SERVER 権限のいずれかが必要です。
既存の可用性グループ リスナーを変更するには 可用性グループの ALTER AVAILABILITY GROUP 権限、CONTROL AVAILABILITY GROUP 権限、ALTER ANY AVAILABILITY GROUP 権限、または CONTROL SERVER 権限が必要です。

リスナーを作成する

コピーのみのバックアップは、SQL Server Management Studio (SSMS)、Transact-SQL、または PowerShell を使用して作成できます。

ヒント

可用性グループウィザードを使用して、可用性グループ リスナーを作成します。

SSMS で可用性グループのリスナーの作成または構成には、以下の手順に従います。

  1. オブジェクト エクスプローラーで、可用性グループのプライマリ レプリカをホストするサーバー インスタンスに接続し、サーバー名をクリックしてサーバー ツリーを展開します。

  2. [Always On 高可用性] ノードと [可用性グループ] ノードを展開します。

  3. リスナーを構成する可用性グループを選択し、次のいずれかを選択します。

    • リスナーを作成するには、 [可用性グループ リスナー] ノードを右クリックし、 [新しいリスナー] をクリックします。 これにより、[新しい可用性グループ リスナー] ダイアログ ボックスが開きます。 詳細については、このトピックの後半の「[新しい可用性グループ リスナー] (ダイアログ ボックス)」を参照してください。

    • 既存のリスナーのポート番号を変更するには、 [可用性グループ リスナー] ノードを展開し、リスナーを右クリックして、 [プロパティ] をクリックします。 [ポート] フィールドに新しいポート番号を入力し、[はい]を選択します。

[新しい可用性グループ リスナー] (ダイアログ ボックス)

[リスナーの DNS 名]
可用性グループ リスナーの DNS ホスト名を指定します。 DNS 名は、ドメインおよび NetBIOS 内で一意であることが必要な文字列です。 この名前には、英数字、ダッシュ (-)、およびハイフン (_) のみを任意の順序で含めることができます。 DNS ホスト名では大文字と小文字は区別されません。 最大長は 15 文字です。

詳細については、このトピックの前半の「可用性グループ リスナーの DNS 名の要件」を参照してください。

ポート
このリスナーで使用される TCP ポート。

[ネットワーク モード]
リスナーで使用される TCP プロトコルを指定します。次のいずれかです。

[DHCP]
リスナーは、動的ホスト構成プロトコル (DHCP) を実行しているサーバーによって割り当てられる動的 IP アドレスを使用します。 DHCP は、単一のサブネットに制限されます。

重要

運用環境での DHCP の使用はお勧めしません。 ダウンタイムが発生して DHCP IP のリース期限が切れると、リスナーの DNS 名に関連付けられている新しい DHCP のネットワーク IP アドレスの登録に余分な時間がかかり、クライアント接続に影響が及びます。 ただし、開発環境とテスト環境を設定して可用性グループの基本機能を確認する場合や、アプリケーションとの統合の場合には DHCP が適しています。

[静的 IP]
リスナーは、1 つまたは複数の静的 IP アドレスを使用します。 必要に応じて追加の IP アドレスを指定できます。 複数のサブネットにわたる可用性グループ リスナーを作成するには、各サブネットのリスナー構成に静的 IP アドレスを指定する必要があります。 これらの静的 IP アドレスを取得するには、ネットワーク管理者に問い合わせてください。

[静的 IP] を選択した場合、 [ネットワーク モード] フィールドの下にサブネット グリッドが表示されます。 このグリッドに、この可用性グループ リスナーによってアクセスできる各サブネットについての情報が表示されます。 このグリッドは、[追加]を選択して静的 IP アドレスを追加するまでは空です。

次の列で構成されます。

サブネット
可用性グループ リスナーに追加される各サブネットの識別子が表示されます。

IP アドレス
特定のサブネットの IP アドレスが表示されます。 サブネットの IP アドレスには、IPv4 アドレスまたは IPv6 アドレスを使用できます。

追加
選択したサブネットまたはこのリスナーの別のサブネットに静的 IP アドレスを追加する場合に選択します。 クリックすると、 [IP アドレスの追加] ダイアログ ボックスが開きます。 詳細については、「IP アドレスの追加ダイアログ ボックス」ヘルプ記事を参照してください。

削除
選択したサブネットをこのリスナーから削除する場合に選択します。

[OK]
指定した可用性グループ リスナーを作成する場合に選択します。

トラブルシューティング

Active Directory クォータが原因で可用性グループ リスナーの作成が失敗

参加するクラスターノードのマシンアカウントが Active Directoryの制限に達しているため、新しい可用性グループリスナーの作成に失敗する場合があります。 詳細については、「コンピューター オブジェクト変更時のクラスター サービス アカウントのトラブルシューティング方法」を参照してください。

補足情報: 可用性グループ リスナーの作成後

MultiSubnetFailover のキーワードおよび関連機能

MultiSubnetFailover は、SQL Server 2012 の Always On 可用性グループおよび Always On フェールオーバー クラスター インスタンスに対して高速フェールオーバーを有効にするために使用する新しい接続文字列キーワードです。 接続文字列で MultiSubnetFailover=True が設定されている場合、次の 3 つのサブ機能が有効になります。

  • Always On 可用性グループまたはフェールオーバー クラスター インスタンスに対する複数サブネット リスナーへのより高速なマルチサブネット フェールオーバー。

  • Always On 可用性グループまたはフェールオーバー クラスター インスタンスの単一サブネット リスナーへのより高速な単一サブネット フェールオーバー。

    • この機能は、単一のサブネット内に単一の IP を持つリスナーに接続する場合に使用されます。 TCP 接続の再試行をより積極的に実行して、単一サブネット フェールオーバーを高速化します。
  • マルチサブネット AlwaysOn フェールオーバー クラスター インスタンスへの名前付きインスタンスの解決。

    • 複数サブネット エンドポイントを持つ AlwaysOn フェールオーバー クラスター インスタンスの名前付きインスタンス解決サポートを追加します。

.NET Framework 3.5 および OLEDB で MultiSubnetFailover=True はサポートされない

問題: 可用性グループまたはフェールオーバークラスターインスタンスに、異なるサブネットの複数のIPアドレスに依存するリスナー名 (WSFCクラスターマネージャーではネットワーク名またはクライアントアクセスポイントと呼ばれます) があり、ADO.NET とのいずれかを使用している場合。NET Framework 3.5SP1または SQL Native Client 11.0 OLEDBを使用している場合、可用性グループリスナーへのクライアント接続要求の50%が接続タイムアウトに達する可能性があります。

回避策: 次のいずれかのタスクを実行することをお勧めします。

  • クラスターリソースを操作するアクセス許可がない場合は、接続タイムアウトを30秒に変更します (この値は、20秒のTCPタイムアウトと10秒のバッファーになります)。

    長所: :クロスサブネット フェールオーバーが発生した場合、クライアントの復旧時間が短くなります。

    短所:半数のクライアント接続に 20 秒以上要します

  • クラスター リソースを操作する権限がある場合は、可用性グループ リスナーのネットワーク名を RegisterAllProvidersIP=0に設定する方法をお勧めします。 詳細については、このセクションの「RegisterAllProvidersIP の設定」を参照してください。

    長所:クライアント接続のタイムアウト値を大きくすることは必要ありません。

    短所: クロスサブネット フェールオーバーが発生した場合、クロスサイト DNS/AD レプリケーション スケジュールの HostRecordTTL 設定によっては、クライアントの復旧時間が 15 分以上になる可能性があります。

RegisterAllProvidersIP の設定

SQL Server Management Studio、Transact-SQL、または PowerShell を使用して可用性グループ リスナーを作成すると、WSFC にクライアント アクセス ポイントが作成され、その RegisterAllProvidersIP プロパティが 1 (true) に設定されます。 このプロパティ値の効果は、次に示すように、クライアント接続文字列によって異なります。

  • MultiSubnetFailover を true に設定する接続文字列

    Always On 可用性グループは、クライアント接続文字列で、推奨どおり MultiSubnetFailover = True を指定しているクライアントのフェールオーバー後の再接続時間を短縮するために、RegisterAllProvidersIP プロパティを 1 に設定します。 リスナーのマルチサブネット機能を活用するには、クライアントに MultiSubnetFailover キーワードをサポートするデータ プロバイダーが必要な場合があります。 マルチサブネット フェールオーバーのドライバー サポートについては、「Always On クライアント接続」を参照してください。

    マルチサブネット クラスタリングについては、「SQL Server マルチサブネット クラスタリング」を参照してください。

    ヒント

    RegisterAllProvidersIP = 1のときに、WSFC クラスターに対して WSFC の構成の検証ウィザードを実行すると、次の警告メッセージが表示されます。

    "ネットワーク名 'Name:' の RegisterAllProviderIP プロパティは 1 に設定されています。現在のクラスター構成の場合、この値は 0 に設定する必要があります。"

    このメッセージは無視してください。

  • MultiSubnetFailover を true に設定しない接続文字列

    RegisterAllProvidersIP = 1の場合、接続文字列で MultiSubnetFailover = Trueを使用しないどのクライアントも、接続の待機時間が長くなります。 これが発生するのは、このようなクライアントはすべての IP への接続を順に試行するためです。 これに対し、 RegisterAllProvidersIP を 0 に変更すると、WSFC クラスターのクライアント アクセス ポイントにアクティブな IP アドレスが登録され、レガシ クライアントの待機時間が短縮されます。 したがって、可用性グループ リスナーに接続する必要がり、MultiSubnetFailover プロパティを使用できないレガシ クライアントがある場合には、RegisterAllProvidersIP を 0 に変更することをお勧めします。

    重要

    WSFC クラスター (フェールオーバー クラスター マネージャーの GUI) を通して可用性グループ リスナーを作成すると、 RegisterAllProvidersIP は既定で 0 (false) になります。

HostRecordTTL の設定

既定では、クライアントは 20 分間、クラスター DNS レコードをキャッシュします。 キャッシュレコードの Time to Live (TTL)である HostRecordTTL を短くすることで、レガシーなクライアントはより迅速に再接続できる可能性があります。 ただし、HostRecordTTL を小さくすると、設定は DNS サーバーへのトラフィックが増加する可能性があります。

RegisterAllProvidersIP を無効にし、TTL を短縮する PowerShell サンプル スクリプト

次の PowerShell の例では、リスナー リソースに対する RegisterAllProvidersIP クラスター パラメーターと HostRecordTTL クラスター パラメーターの両方を構成する方法を示しています。 DNS レコードは、既定の 20 分間ではなく、5 分間キャッシュされます。 両方のクラスター パラメーターを変更すると、MultiSubnetFailover パラメーターを使用できないレガシ クライアントのフェールオーバーが発生した後に、正しい IP アドレスに接続する時間が短縮される可能性があります。 yourListenerNameは、変更対象のリスナーの名前に置き換えてください。

Import-Module FailoverClusters
Get-ClusterResource yourListenerName | Set-ClusterParameter RegisterAllProvidersIP 0
Get-ClusterResource yourListenerName | Set-ClusterParameter HostRecordTTL 300
Stop-ClusterResource yourListenerName
Start-ClusterResource yourListenerName
Start-Clustergroup yourListenerGroupName

フェールオーバー中の復旧時間の詳細については、「 Client Recovery Latency During Failover」を参照してください。

補足情報: 推奨事項

可用性グループ リスナーを作成した後:

  • リスナーの IP アドレスが排他的に使用されるように確保することを、ネットワーク管理者に依頼します。

  • この可用性グループへのクライアント接続を要求するときの接続文字列で使用できるよう、リスナーの DNS ホスト名をアプリケーション開発者に通知します。

  • 可能であれば、 MultiSubnetFailover = Trueを指定するようにクライアント接続文字列を更新することを開発者に勧めます。 マルチサブネット フェールオーバーのドライバー サポートについては、「Always On クライアント接続」を参照してください。

可用性グループの追加のリスナーの作成 (オプション)

SQL Server で 1 つのリスナーを作成した後、次の手順で追加のリスナーを追加できます。

次のツールのいずれかを使用してリスナーを作成します。

WSFC フェールオーバー クラスター マネージャーの使用:

  1. クライアント アクセス ポイントを追加し、IP アドレスを構成します。

  2. リスナーをオンラインにします。

  3. WSFC 可用性グループに対する依存関係を追加します。

    フェールオーバー クラスター マネージャーのダイアログ ボックスおよびタブの詳細については、「 ユーザー インターフェイス: フェールオーバー クラスター マネージャー スナップイン」を参照してください。

フェールオーバー クラスターの Windows PowerShell の使用:

  1. Add-ClusterResource を使用して、ネットワーク名と IP アドレス リソースを作成します。

  2. Start-ClusterResource を使用して、ネットワーク名リソースを開始します。

  3. Add-ClusterResourceDependency を使用して、ネットワーク名と、既存の SQL Server 可用性グループ リソース間の依存関係を設定します。

    フェールオーバー クラスターの Windows PowerShell の詳細については、「 サーバー マネージャーのコマンドの概要」を参照してください。

SQL Server で新しいリスナーのリッスンを開始します。 追加リスナーを作成した後、プライマリ レプリカをホストする SQL Server のインスタンスに接続し、SQL Server Management Studio、Transact-SQL、または PowerShell を使用してリスナー ポートを変更します。

詳細については、「 同じ可用性グループの複数のリスナーを作成する方法 」(SQL Server AlwaysOn チームのブログ) を参照してください。