Репликацию базы данных выполняет другое средство чтения журнала.
Более одного текущего соединения пытаются выполнить одну из следующих процедур: 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 Management Studio)" в электронной документации по SQL Server.
Перезапустите службу агента (введите ее в кластер в оперативном или автономном режиме) на распространителе. Если существует возможность, что запланированное задание могло выполнять процедуру sp_repldone, sp_replcmds илиsp_replshowcmds из каких-либо других экземпляров, перезапустите агент и для этих экземпляров. Дополнительные сведения см. в разделе "Запуск, остановка и приостановка службы агента SQL Server" электронной документации по SQL Server.
Выполните процедуру sp_replflush в базе данных публикации на издателе, затем перезапустите агент чтения журнала.
Если ошибка продолжает возникать, увеличьте протоколирование агента и укажите выходной файл для журнала. В зависимости от контекста ошибки эта мера может помочь в определении шагов, которые привели к ошибке или появлению дополнительных сообщений об ошибке. Дополнительные сведения см. в разделе "Агенты репликации (диагностика)" в электронной документации по SQL Server.
Имя | Описание | Значение по умолчанию |
Вкл. | Включает или отключает рабочий процесс. | Да |
Приоритет | Определяет приоритет предупреждения. | 2 |
Серьезность | Определяет серьезность предупреждения. | 2 |
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>Event ID: $Data/EventDisplayNumber$. $Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue>$Data/LoggingComputer$</SuppressionValue>
<SuppressionValue>$Data/PublisherName$</SuppressionValue>
<SuppressionValue>$Data/EventDisplayNumber$</SuppressionValue>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>