可用性グループ オンライン
このモニターは、可用性グループの状態がオンラインかオフラインかを調べます。モニターが異常となって警告が生成されるのは、可用性グループのクラスター リソースがオフラインであるか、可用性グループにプライマリ レプリカがない場合です。モニター状態が正常となるのは、可用性グループのクラスター リソースがオンラインであり、かつ可用性グループにプライマリ レプリカがある場合です。
可用性グループはオフラインであり、使用できません。この問題は、プライマリ レプリカをホストするサーバー インスタンスのエラー、またはオフラインになっている WSFC 可用性グループ リソースによって発生する可能性があります。
可用性グループに自動フェールオーバー モードが構成されておらず、プライマリ レプリカが使用不可能で、可用性グループ内にあるすべてのレプリカのロールが RESOLVING になっています。
プライマリ レプリカ インスタンス サービスが停止しているか応答しません。
可用性グループのクラスターへの接続に問題があります。
可用性グループに自動フェールオーバー モードが構成されていますが、エラーのため自動フェールオーバーは正常に完了しませんでした。
自動フェールオーバー時に、ターゲット レプリカのプライマリ準備状態検査が不合格になり、新しいプライマリとなるレプリカが 1 つもありません。
クラスターの可用性グループ リソースがオフラインになりました。
従属クラスター リソースの 1 つに重大な問題が発生してオフラインになったため、その従属リソースがオンラインになるまでの間は可用性グループ リソースがオフラインになります。
クラスターでの重要な問題により、可用性グループ リソースがオフになりました。
可用性グループの自動、手動、強制フェールオーバーが進行中です。
プライマリ レプリカの SQL Server インスタンスが停止している場合は、再起動して、可用性グループが正常な状態に回復するかどうかを確認します。
自動フェールオーバーに失敗したと思われる場合は、すべてのデータベースが以前の既知のプライマリと同期しているレプリカがあるかどうかを調べて、そのレプリカにフェールオーバーします。それ以外の場合は、データ損失が最小のレプリカを選択して、フェールオーバーまたは強制フェールオーバーに復旧します。
SQL Server インスタンスが正常であるように見えるにもかかわらずクラスター内のリソースがオフラインである場合は、クラスターの正常性や問題の有無をクラスター マネージャーを使用して調べます。クラスター管理ツールを使用して、可用性グループ リソースをオンラインにすることもできます。
実行中のフェールオーバーがある場合は、完了するまで待ちます。
名前 | 説明 | 既定値 |
有効 | ワークフローを有効または無効にします。 | はい |
アラートを生成する | ワークフローがアラートを生成するかどうかを定義します。 | いいえ |
間隔 (秒) | ワークフローを実行する定期的な実行間隔 (秒)。 | 900 |
同期時刻 | 24 時間形式で指定した同期時刻。省略可能です。 |
|
タイムアウト (秒) | ワークフローが終了して失敗とマークされるまでの、ワークフローの許容実行時間を指定します。 | 300 |
データベース接続のタイムアウト (秒) | 指定された期間中にデータベースにアクセスできない場合、ワークフローは失敗し、イベントが登録されます。 | 15 |
Target | Microsoft.SQLServer.Windows.AvailabilityGroupHealth |
Parent Monitor | System.Health.AvailabilityState |
Category | AvailabilityHealth |
Enabled | True |
Alert Generate | False |
Alert Auto Resolve | True |
Monitor Type | Microsoft.SQLServer.Windows.MonitorType.AlwaysOnSystemPolicyWithSampling |
Remotable | True |
Accessibility | Public |
RunAs | Default |
<UnitMonitor ID="Microsoft.SQLServer.Windows.Monitor.AvailabilityGroupHealth.AvailabilityGroupOnline" Accessibility="Public" Enabled="true" Target="SqlDiscW!Microsoft.SQLServer.Windows.AvailabilityGroupHealth" ParentMonitorID="Health!System.Health.AvailabilityState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.Windows.MonitorType.AlwaysOnSystemPolicyWithSampling" ConfirmDelivery="false">
<Category>AvailabilityHealth</Category>
<OperationalStates>
<OperationalState ID="Success" MonitorTypeStateID="HealthState" HealthState="Success"/>
<OperationalState ID="Critical" MonitorTypeStateID="ErrorState" HealthState="Error"/>
</OperationalStates>
<Configuration>
<MachineName>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/MachineName$</MachineName>
<NetbiosComputerName>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/NetbiosComputerName$</NetbiosComputerName>
<InstanceName>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/InstanceName$</InstanceName>
<ConnectionString>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/ConnectionString$</ConnectionString>
<InstanceVersion>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/Version$</InstanceVersion>
<InstanceEdition>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/Edition$</InstanceEdition>
<MonitoringType>$Target/Host/Property[Type="SqlDiscW!Microsoft.SQLServer.Windows.DBEngine"]/MonitoringType$</MonitoringType>
<PolicyName>AlwaysOnAgOnlineStateHealthPolicy</PolicyName>
<BagKey>1-$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.AvailabilityGroupHealth"]/AvailabilityGroupName$</BagKey>
<NumSamples>2</NumSamples>
<SqlExecTimeoutSeconds>60</SqlExecTimeoutSeconds>
<SqlTimeoutSeconds>15</SqlTimeoutSeconds>
<TimeoutSeconds>300</TimeoutSeconds>
<IntervalSeconds>900</IntervalSeconds>
<SyncTime/>
</Configuration>
</UnitMonitor>