Sie sind zurzeit offline. Es wird auf die erneute Herstellung einer Internetverbindung gewartet.

Update: Ein blockierender Problem tritt auf, wenn Sie den Merge-Agent in SQL Server 2005 ausführen

Extended support for SQL Server 2005 ends on April 12, 2016

If you are still running SQL Server 2005 after April 12, 2016, you will no longer receive security updates and technical support. We recommend upgrading to SQL Server 2014 and Azure SQL Database to achieve breakthrough performance, maintain security and compliance, and optimize your data platform infrastructure. Learn more about the options for upgrading from SQL Server 2005 to a supported version here.

Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.

Den englischen Originalartikel können Sie über folgenden Link abrufen: 959023
Problembeschreibung
In SQL Server 2005 konfigurieren Sie eine Mergepublikation. Eine Blockierung Problem tritt beim Ausführen des Merge-Agents. Wenn Sie das blockierende Problem überwachen, finden Sie die folgenden Verhaltensweisen:
  • In der Ausgabe des blockierenden Skripts, die Sie, erstellt um dieses Problem zu überwachen, werden einige Threads, die gespeicherten Replikationsprozeduren ausgeführt werden blockiert. Sie können beispielsweise auftreten, dass die blockierten Threads die folgenden gespeicherten Replikationsprozeduren ausgeführt werden:
    • Die Sp_MSinsertgenhistory, die gespeicherte Prozedur
    • Die Sp_MSgetmakegenerationappl, die gespeicherte Prozedur
    • Die Sp_MSenumgenerations, die gespeicherte Prozedur
    Hinweis: Sie finden auch die Threads, die mithilfe der Aktivitätsmonitor in SQL Server Management Studio gesperrt sind.

    Weitere Informationen, wie ein Problem durch Erstellen eines blockierenden Skripts überwacht finden Sie im folgenden Artikel der Microsoft Knowledge Base:
    271509Zum Überwachen von Sperren in SQL Server 2005 und in SQL Server 2000
  • In einer SQL Server-Ablaufverfolgung kann eine Transaktion, die über die Sp_mergemetadataretentioncleanup gespeicherte Prozedur geöffnet wird noch ausgeführt, obwohl die gespeicherte Prozedur, die die Sp_mergemetadataretentioncleanup gespeicherte Prozedur aufruft abgeschlossen wurde. Darüber hinaus finden Sie möglicherweise eine Attention-Ereignis in der Transaktion. Die gespeicherte Prozedur, die die Sp_mergemetadataretentioncleanup gespeicherte Prozedur aufruft, kann eine der folgenden gespeicherten Prozeduren sein:
    • Die Sp_MSinsertgenhistory, die gespeicherte Prozedur
    • Die Sp_MSgetmakegenerationappl, die gespeicherte Prozedur
    • Die Sp_MSenumgenerations gespeicherte Prozedur.
    Sie können z. B. Datensätze suchen, die in der SQL Server-Ablaufverfolgung folgendermaßen aussehen:
    EventClass TextData Objektname DBID Transaktions-ID HostName ClientProcessID Anwendungsname SPID
    RPC: Completed Exec-Sp_MSenumgenerations 1051201 '9B9CC268-A43A-4736-9481-0B99227C3BF0", 1 sp_Msenumgenerations 5 525491216 HostName1896 ApplicationName69
    EventClass TextData Objektname DBID Transaktions-ID HostName ClientProcessID Anwendungsname SPID
    SP: StmtCompletedTransaktion beginnensp_mergemetadataretentioncleanup5 525491216 HostName1896 ApplicationName69
    SP: StmtStarting Wählen Sie NULL aus dbo.MSmerge_contents mit (TABLOCK HOLDLOCK), wobei 1 = 2sp_mergemetadataretentioncleanup5 525491216 HostName1896 ApplicationName69
    EventClass TextData Objektname DBID Transaktions-ID HostName ClientProcessID Anwendungsname SPID
    Aufmerksamkeit5 525491216 HostName1896 ApplicationName69
Ursache
Dieses Problem tritt da der Zusammenführung Metadaten Cleanup-Prozess nicht die Option XACT_ABORT auf ON für die Buchung festgelegt ist. Wenn die Sp_mergemetadataretentioncleanup gespeicherte Prozedur ausgeführt wird, wenn eine unerwartete Ausnahme wie z. B. ein Netzwerkproblem auftritt, Rollback der Transaktion ist nicht. Wenn keine Rollback der Transaktion ausgeführt wird, wird die Lock-Ressourcen, die von der Transaktion aufrechterhalten werden nicht freigegeben.
Lösung

Informationen zu Service Packs

Installieren Sie das neueste Servicepack für SQL Server 2005, um dieses Problem zu beheben. Weitere Informationen finden Sie im folgenden Artikel der Microsoft Knowledge Base:
913089Beziehen der neuesten Service Packs für SQL Server 2005
Status
Microsoft hat bestätigt, dass dies ein Problem in Microsoft-Produkten handelt, die im Abschnitt "Gilt für" aufgeführt sind. Dieses Problem wurde erstmals im SQL Server 2005 Service Pack 3.
Weitere Informationen
Weitere Informationen zur Terminologie für Softwareupdates finden Sie im folgenden Artikel der Microsoft Knowledge Base:
824684Erläuterung von Standardbegriffen bei Microsoft Softwareupdates

Eigenschaften

Artikelnummer: 959023 – Letzte Überarbeitung: 12/16/2008 01:06:07 – Revision: 1.0

Microsoft SQL Server 2005 Standard Edition, Microsoft SQL Server 2005 Developer Edition, Microsoft SQL Server 2005 Enterprise Edition, Microsoft SQL Server 2005 Standard X64 Edition, Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems, Microsoft SQL Server 2005 Enterprise X64 Edition, Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems, Microsoft SQL Server 2005 Workgroup Edition

  • kbmt kbsql2005repl kbexpertiseadvanced kbtshoot kbfix kbbug KB959023 KbMtde
Feedback