ページの予測保持期間

Microsoft.SQLServer.2012.DBEngine.PageLifeExpectancyMonitor (UnitMonitor)

2012 DB エンジンのページの予測保持期間 (秒)

Knowledge Base article:

概要

ページ予測保持期間は、ページが参照されないままバッファー プールに存在する秒数です。ページ予測保持期間が長い場合、必要なデータはハード ドライブに移動せずにキャッシュにあります。

原因

ページの予測保持期間の値が著しく低い場合は、次の状況を示している可能性があります。

システムのメモリが少なすぎる

SQL Server 用に構成されたメモリが少なすぎる

インデックスの設計が適切でない

解決方法

I/O システムで負荷の処理状態を確認してください。PhysicalDisk オブジェクトの 1 秒間のディスク読み取りの平均および 1 秒間のディスク書き込みの平均のカウンター値が高い場合 (通常は 10 ミリ秒を超える場合) は、システムがオーバーロードしているか、クエリやインデックスに改善の余地があることを意味します。

SQL Server で大量のテーブルを同時に使用しているか、抽出条件による検索の代わりにフル スキャンが使用されているため、バッファー プールがオーバーロードになっている可能性があります。SQL Server の Access Methods の Full Scans/sec カウンターで問題を確認します。

SQL Server Profiler を使用し、パフォーマンス カテゴリの Showplan Statistics を参照すると、フル スキャンを引き起こしているアプリケーションを特定できることがあります。

Element properties:

TargetMicrosoft.SQLServer.2012.DBEngine
Parent MonitorSystem.Health.PerformanceState
CategoryPerformanceHealth
EnabledTrue
Alert GenerateTrue
Alert SeverityError
Alert PriorityNormal
Alert Auto ResolveTrue
Monitor TypeMicrosoft.SQLServer.2012.DBEngine.PageLifeExpectancy.MonitorType
RemotableTrue
AccessibilityPublic
Alert Message
SQL DB エンジン 2012 のページの予測保持期間が短すぎます
コンピューター "{1}" 上の SQL インスタンス "{0}" のページの予測保持期間が短すぎます。詳しくは、[アラートのコンテキスト] タブを参照してください。
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.SQLServer.2012.DBEngine.PageLifeExpectancyMonitor" Accessibility="Public" Enabled="true" Target="SQL2012Core!Microsoft.SQLServer.2012.DBEngine" ParentMonitorID="SystemHealth!System.Health.PerformanceState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2012.DBEngine.PageLifeExpectancy.MonitorType" ConfirmDelivery="false">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2012.DBEngine.PageLifeExpectancyMonitor.AlertMessage">
<AlertOnState>Error</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>Error</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Target/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</AlertParameter1>
<AlertParameter2>$Target/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</AlertParameter2>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState ID="Normal" MonitorTypeStateID="Normal" HealthState="Success"/>
<OperationalState ID="Error" MonitorTypeStateID="Error" HealthState="Error"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>900</IntervalSeconds>
<Threshold>300</Threshold>
</Configuration>
</UnitMonitor>