別のログ リーダーがデータベースをレプリケートしています。
複数の現在の接続が、sp_repldone、sp_replcmds、sp_replshowcmds のいずれかを実行しようとしています。ログ リーダー エージェントは、ストアド プロシージャ sp_repldone と sp_replcmds を使用して、パブリッシュされたデータベース内のレプリケートされたトランザクションに関する情報を検索および更新します。ストアド プロシージャ sp_replshowcmds は、トランザクション レプリケーションに関する特定の問題点に対するトラブルシューティングを行うために使用されます。
このエラーは、次の状況で発生します。
パブリッシュされたデータベースのログ リーダー エージェントが実行されており、2 番目のログ リーダー エージェントの実行を同じデータベースに対して試みた場合、2 番目のエージェントに対してエラーが発生し、エージェント履歴に表示されます。
複数のエージェントが存在する状況では、いずれかのエージェントは孤立したプロセスが原因の可能性があります。
パブリッシュされたデータベースに対してログ リーダー エージェントが起動されており、ユーザーが sp_repldone、sp_replcmds、または sp_replshowcmds を同じデータベースに対して実行する場合は、ストアド プロシージャ (sqlcmd など) が実行されるとアプリケーションでエラーが発生します。
パブリッシュされたデータベースに対してログ リーダー エージェントが実行されておらず、ユーザーが sp_repldone、sp_replcmds、または sp_replshowcmds を実行してから、プロシージャを実行した接続を閉じない場合は、ログ リーダー エージェントによってデータベースへの接続が試行されるとエラーが発生します。
複数のエージェントがあると思われる状況では、そのいずれかがなんらかの孤立したプロセスの結果である可能性があり、その場合は余分なジョブまたはエージェントとして Management Studio に表示されません。
次の手順を実行して、この問題に対するトラブルシューティングに役立てることができます。いずれかの手順によって、ログ リーダー エージェントをエラーを発生させないで起動できるようになった場合は、残りの手順を実行する必要はありません。
このエラーの発生原因となる可能性があるその他のエラーについて、ログ リーダー エージェントの履歴を確認します。レプリケーション モニターでエージェントの状態やエラーの詳細を表示する方法については、SQL Server オンライン ブックの「パブリケーションに関連付けられているエージェントの情報を表示したりタスクを実行する方法 (レプリケーション モニター)」を参照してください。
パブリッシュされたデータベースに接続されている特定のプロセス識別番号 (SPID) に対応する sp_who の出力を確認します。sp_repldone、sp_replcmds、または sp_replshowcmds を実行していた可能性のある接続をすべて閉じます。
ログ リーダー エージェントを再起動します。詳細については、SQL Server オンライン ブックの「レプリケーション エージェントの起動および停止方法 (SQL Server Management Studio)」を参照してください。
ディストリビューターでエージェント サービスを再起動します (クラスター内でオフラインまたはオンラインにします)。スケジュールされたジョブがその他のインスタンスから sp_repldone、sp_replcmds、または sp_replshowcmds を実行した可能性がある場合は、これらのインスタンスに対してもエージェントを再起動します。詳細については、SQL Server オンライン ブックの「SQL Server エージェント サービスの開始、停止、および一時停止」を参照してください。
パブリケーション データベース上のパブリッシャーで 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>