パブリケーションの初期スナップショットはまだ使用できません

Microsoft.SQLServer.2008.InitialSnapshotForPublicationIsNotYetAvailableRule (Rule)

Knowledge Base article:

概要

アーティクル キャッシュ アクセス イベントで待機中にエラーが SQL Server ログに記録されました。

原因

上記のエラーは、次の状況で表示されます。

マージ レプリケーションの場合:

マージ サブスクリプションを作成または再初期化し、スナップショット エージェントを開始する前またはスナップショット エージェントが完了する前にマージ エージェントを開始したときに、このエラーが表示されます。

トランザクション レプリケーションの場合:

[はい、スキーマとデータを初期化します] オプション付きで作成されたトランザクション サブスクリプションを作成または再初期化し、スナップショット エージェントを開始する前またはスナップショット エージェントが完了する前にディストリビューション エージェントを開始しました。このサブスクリプションがディストリビューション エージェントに関連付けられた唯一のサブスクリプションである場合、またはディストリビューション エージェントに関連付けられたすべてのサブスクリプションが上記の状態になっている場合にのみ、このエラーが発生します。ディストリビューション エージェントに関連付けられたいずれかのサブスクリプションでスナップショットが利用可能になると同時に、エージェントの履歴メッセージには "使用できるレプリケートされたトランザクションが存在しません。" という内容が表示されるか、このエージェントに関連付けられた他のサブスクリプションで配布されたトランザクションとコマンドの数が報告されます。トランザクション パブリケーションにアーティクルが 1 つしかなく、そのアーティクルが上記の基準を満たしている場合は、エラーが 21076 "アーティクルの初期スナップショットはまだ使用できません。" になります。

解決方法

サブスクリプションの作成または最後の再初期化後、関連付けられたスナップショット エージェントがまだ開始していない場合は、スナップショット エージェントを開始し、その完了後にマージ エージェントまたはディストリビューション エージェントを開始する必要があります。

スナップショット エージェントが完了しない場合は、スナップショット エージェントの履歴でエラーを確認して対応します。必要であれば、スナップショット エージェントにログを追加することにより、表示されるエラーに関してより詳しい情報が返されるかどうかを確認できます。

外部資料

SQL Server のレプリケーション エージェントで出力ファイルへのログ出力を有効にする方法

Element properties:

TargetMicrosoft.SQLServer.2008.DBEngine
CategoryEventCollection
EnabledTrue
Alert GenerateTrue
Alert SeverityWarning
Alert PriorityNormal
RemotableTrue
Alert Message
パブリケーションの初期スナップショットはまだ使用できません
{0}

Member Modules:

ID Module Type TypeId RunAs 
DS DataSource Microsoft.SQLServer.2008.EventProvider Default
GenerateAlert WriteAction System.Health.GenerateAlert Default

Source Code:

<Rule ID="Microsoft.SQLServer.2008.InitialSnapshotForPublicationIsNotYetAvailableRule" 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>21075</EventNumber>
</DataSource>
</DataSources>
<WriteActions>
<WriteAction ID="GenerateAlert" TypeID="SystemHealth!System.Health.GenerateAlert">
<Priority>1</Priority>
<Severity>1</Severity>
<AlertMessageId>$MPElement[Name="Microsoft.SQLServer.2008.InitialSnapshotForPublicationIsNotYetAvailableRule.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>