此監視器會針對發行集,檢查複寫記錄讀取器代理程式服務的狀態。
複寫記錄讀取器代理程式是可執行檔,其會監視針對交易式複寫所設定之每個資料庫的交易記錄檔。記錄讀取器代理程式會將標示為要複寫的交易從交易記錄檔複製到散發資料庫中。
記錄讀取器代理程式可能會因為下述原因而失敗:
記錄讀取器代理程式無法連接至發行者資料庫或散發資料庫。
記錄讀取器代理程式無法在發行者資料庫上執行 sp_replcmds/sp_replcounters。
記錄讀取器代理程式無法在發行者資料庫上執行 sp_repldone。
記錄讀取器代理程式因發生查詢逾時錯誤而失敗。
非互動式桌面堆積的記憶體耗盡。
傳遞給代理程式可執行檔的參數不正確。
這個問題可透過下列方法來解決:
正在將 dbo 存取權授與發行者登入。
增加查詢逾時參數值,並確定記錄讀取器代理程式並未被封鎖或並未在等待任何資源
使用發行者登入帳戶,在發行者資料庫上手動執行 sp_replcmds。
執行 sp_replflush,以清除在發行者資料庫上執行複寫預存程序的任何其他用戶端。
確認已將正確的參數傳遞至代理程式可執行檔。
依照 http://support.microsoft.com/kb/949296 的指示,增加桌面堆積
http://technet.microsoft.com/library/ms146878.aspx
名稱 | 描述 | 預設值 |
已啟用 | 啟用或停用工作流程 | 是 |
產生警示 | 定義工作流程是否產生警示 | 是 |
間隔 (秒) | 執行工作流程的週期性時間間隔 (秒)。 | 300 |
顯示未知狀態的作業 | 包括監視輸出和警示內容為未知狀態的作業。將會影響健全狀況 | 否 |
逾時 (秒) | 逾時 (秒) | 300 |
同步處理時間 | 同步處理時間 |
|
Target | Microsoft.SQLServer.2014.Replication.Publication | ||
Parent Monitor | System.Health.PerformanceState | ||
Category | PerformanceHealth | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | Error | ||
Alert Priority | Normal | ||
Alert Auto Resolve | True | ||
Monitor Type | Microsoft.SQLServer.2014.Replication.MonitorType.ReplicationAgentState | ||
Remotable | True | ||
Accessibility | Internal | ||
Alert Message |
| ||
RunAs | Microsoft.SQLServer.Replication.Monitoring.RunAs.Monitor |
<UnitMonitor ID="Microsoft.SQLServer.2014.Replication.Monitor.PublicationLogReaderAgentState" Accessibility="Internal" Enabled="true" Target="MS2RD!Microsoft.SQLServer.2014.Replication.Publication" ParentMonitorID="Health!System.Health.PerformanceState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2014.Replication.MonitorType.ReplicationAgentState" ConfirmDelivery="false" RunAs="MSRL!Microsoft.SQLServer.Replication.Monitoring.RunAs.Monitor">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2014.Replication.Monitor.PublicationLogReaderAgentState.AlertMessage">
<AlertOnState>Error</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>Error</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Data/Context/Property[@Name='Message']$</AlertParameter1>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState ID="Health" MonitorTypeStateID="Health" HealthState="Success"/>
<OperationalState ID="Error" MonitorTypeStateID="Error" HealthState="Error"/>
<OperationalState ID="Warning" MonitorTypeStateID="Warning" HealthState="Warning"/>
</OperationalStates>
<Configuration>
<SqlTimeout>300</SqlTimeout>
<ConnectionString>$Target/Host/Property[Type='MSRL!Microsoft.SQLServer.Replication.Library.GenericPublisher']/Distributor$</ConnectionString>
<XPathName>Log reader$Target/Host/Property[Type='MSRL!Microsoft.SQLServer.Replication.Library.GenericPublisher']/Distributor$$Target/Host/Property[Type='MSRL!Microsoft.SQLServer.Replication.Library.GenericPublisher']/DistributorDatabaseName$$Target/Host/Property[Type='MSRL!Microsoft.SQLServer.Replication.Library.GenericPublisher']/ConnectionString$$Target/Property[Type='MSRL!Microsoft.SQLServer.Replication.Library.GenericPublication']/PublicationName$</XPathName>
<ShowJobsWithUnknownState>false</ShowJobsWithUnknownState>
<EstimatedJobDuration>15</EstimatedJobDuration>
<IntervalSeconds>300</IntervalSeconds>
<SyncTime/>
</Configuration>
</UnitMonitor>