此監視器會針對發行集,檢查複寫記錄讀取器代理程式服務的狀態。
複寫記錄讀取器代理程式是可執行檔,其會監視針對交易式複寫所設定之每個資料庫的交易記錄檔。記錄讀取器代理程式會將標示為要複寫的交易從交易記錄檔複製到散發資料庫中。
記錄讀取器代理程式可能會因為下列原因失敗:
記錄讀取器代理程式無法連接至發行者資料庫或散發資料庫。
記錄讀取器代理程式無法在發行者資料庫上執行 sp_replcmds/sp_replcounters。
記錄讀取器代理程式無法在發行者資料庫上執行 sp_repldone。
記錄讀取器代理程式因發生查詢逾時錯誤而失敗。
非互動式桌面堆積的記憶體耗盡。
傳遞給代理程式可執行檔的參數不正確。
這個問題可透過下列方法來解決:
正在將 dbo 存取權授與發行者登入。
增加查詢逾時參數值,並確定記錄讀取器代理程式並未被封鎖或並未在等待任何資源
使用發行者登入帳戶,在發行者資料庫上手動執行 sp_replcmds。
執行 sp_replflush,以清除在發行者資料庫上執行複寫預存程序的任何其他用戶端。
請確認傳遞了正確的參數給代理程式可執行檔。
依照 http://support.microsoft.com/kb/949296 的指示,增加桌面堆積
http://technet.microsoft.com/library/ms146878.aspx
名稱 | 描述 | 預設值 |
警示優先程式 | 定義警示優先順序。 | 一般 |
警示嚴重性 | 定義警示嚴重性。 | 錯誤 |
已啟用 | 啟用或停用該工作流程。 | 是 |
估計的作業持續時間 | 用於檢查作業排程相容性的臨界值 | 15 |
產生警示 | 定義工作流程是否會產生警示。 | 是 |
間隔 (秒) | 執行工作流程的週期性時間間隔 (秒)。 | 300 |
顯示具未知狀態的作業 | 將狀態未知的作業加入監視器輸出與警示內容中。這會影響健全狀況。 | 否 |
同步處理時間 | 同步處理時間 |
|
逾時 (秒) | 指定允許工作流程在關閉且標示為失敗之前執行的時間。 | 300 |
資料庫連線的逾時 (秒) | 若工作流程無法在指定的期限之內存取資料庫,將會失敗並登錄一則事件。 | 15 |
Target | Microsoft.SQLServer.2016.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.2016.Replication.MonitorType.ReplicationAgentState | ||
Remotable | True | ||
Accessibility | Internal | ||
Alert Message |
| ||
RunAs | Microsoft.SQLServer.Replication.Monitoring.RunAs.Monitor |
<UnitMonitor ID="Microsoft.SQLServer.2016.Replication.Monitor.PublicationLogReaderAgentState" Accessibility="Internal" Enabled="true" Target="MS2RD!Microsoft.SQLServer.2016.Replication.Publication" ParentMonitorID="Health!System.Health.PerformanceState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2016.Replication.MonitorType.ReplicationAgentState" ConfirmDelivery="false" RunAs="MSRL!Microsoft.SQLServer.Replication.Monitoring.RunAs.Monitor">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2016.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>15</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/>
<TimeoutSeconds>300</TimeoutSeconds>
</Configuration>
</UnitMonitor>