另一個記錄讀取器正在複寫資料庫。
目前有多個連接嘗試執行下列任一項目:sp_repldone、sp_replcmds 或 sp_replshowcmds。記錄讀取器代理程式會使用 sp_repldone 和 sp_replcmds 預存程序,在已發行資料庫中尋找及更新已複寫交易的相關資訊。sp_replshowcmds 預存程序是用來對異動複寫的特定問題進行疑難排解。
此錯誤在下列情況下產生:
如果已發行資料庫的「記錄讀取器代理程式」正在執行,而第二個「記錄讀取器代理程式」嘗試針對相同的資料庫執行,則錯誤就會在第二個代理程式中產生,並且出現在代理程式記錄中。
若出現多個代理程式的情況,則可能其中一個代理程式是被遺棄處理的結果。
如果已發行資料庫的「記錄讀取器代理程式」已啟動,而使用者針對相同的資料庫執行 sp_repldone、sp_replcmds 或 sp_replshowcmds ,則錯誤就會在執行預存程序 (例如 sqlcmd) 的應用程式中產生。
如果已發行資料庫的「記錄讀取器代理程式」未在執行,且使用者執行了 sp_repldone、sp_replcmds 或 sp_replshowcmds,之後也未關閉執行該程序的連接,則當「記錄讀取器代理程式」嘗試連接到資料庫時就會產生錯誤。
請注意,在似乎存在多個代理程式的情況下,其中一個代理程式可能是因為未在 Management Studio 中顯示為額外作業或代理程式的某種孤立處理序所導致。
下列步驟可以幫助您對此問題進行疑難排解。如果任一步驟允許「記錄讀取器代理程式」在沒有錯誤的情況下啟動,則無需完成剩餘步驟。
檢查「記錄讀取器代理程式」的記錄,以便尋找可能導致此錯誤的其他任何錯誤。如需有關在複寫監視器中檢視代理程式狀態和錯誤詳細資料的詳細資訊,請參閱《SQL Server 線上叢書》中的<如何:檢視與發行集相關聯之代理程式的資訊並執行工作 (複寫監視器)>。
檢查 sp_who 的輸出以尋找連接到已發行資料庫之特定處理序識別碼 (SPID)。關閉可能已執行 sp_repldone、sp_replcmds 或 sp_replshowcmds 的任何連接。
重新啟動「記錄讀取器代理程式」。如需詳細資訊,請參閱《SQL Server 線上叢書》中的<如何:啟動和停止複寫代理程式 (SQL Server Management Studio)>。
在「散發者」上重新啟動代理程式服務 (使其在叢集中離線或上線)。如果已排程作業可能已經從任何其他執行個體執行 sp_repldone、sp_replcmds 或 sp_replshowcmds,則一併重新啟動這些執行個體的代理程式。如需詳細資訊,請參閱《SQL Server 線上叢書》中的<啟動、停止和暫停 SQL Server Agent 服務>。
在發行集資料庫上的「發行者」端執行 sp_replflush,然後重新啟動「記錄讀取器代理程式」。
若錯誤繼續發生,請增加代理程式的記錄,並指定記錄的輸出檔。視錯誤內容的不同,可提供導致錯誤的步驟和 (或) 其他錯誤訊息。如需詳細資訊,請參閱《SQL Server 線上叢書》中的<複寫代理程式 (疑難排解)>。
Target | Microsoft.SQLServer.2008.DBEngine | ||
Category | EventCollection | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | Error | ||
Alert Priority | High | ||
Remotable | True | ||
Alert Message |
|
ID | Module Type | TypeId | RunAs |
---|---|---|---|
DS | DataSource | Microsoft.SQLServer.2008.EventProvider | Default |
GenerateAlert | WriteAction | System.Health.GenerateAlert | Default |
<Rule ID="Microsoft.SQLServer.2008.AnotherLogReaderIsReplicatingDatabaseRule" Target="SQL2008Core!Microsoft.SQLServer.2008.DBEngine" Enabled="true" ConfirmDelivery="true">
<Category>EventCollection</Category>
<DataSources>
<DataSource ID="DS" TypeID="Microsoft.SQLServer.2008.EventProvider">
<ComputerName>$Target/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ComputerName>
<PublisherName>$Target/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ServiceName$</PublisherName>
<EventNumber>18752</EventNumber>
</DataSource>
</DataSources>
<WriteActions>
<WriteAction ID="GenerateAlert" TypeID="SystemHealth!System.Health.GenerateAlert">
<Priority>2</Priority>
<Severity>2</Severity>
<AlertMessageId>$MPElement[Name="Microsoft.SQLServer.2008.AnotherLogReaderIsReplicatingDatabaseRule.AlertMessage"]$</AlertMessageId>
<AlertParameters>
<AlertParameter1>$Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue>$Data/LoggingComputer$</SuppressionValue>
<SuppressionValue>$Data/PublisherName$</SuppressionValue>
<SuppressionValue>$Data/EventDisplayNumber$</SuppressionValue>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>