KB2545989-FIX: "si è verificato un timeout durante l'attesa del blocco del buffer" errore quando molte transazioni aggiornano contemporaneamente un database in SQL Server 2008 R2 o in SQL Server 2008 se il database usa il livello di isolamento dello snapshot

Microsoft distribuisce Microsoft SQL Server 2008 R2 o Microsoft SQL Server 2008 correzioni come un file scaricabile. Poiché le correzioni sono cumulative, ogni nuova versione contiene tutti gli hotfix e tutti gli aggiornamenti della sicurezza inclusi nella versione precedente di SQL Server 2008 R2 o SQL Server 2008 FIX.

Sintomi

Considerare lo scenario descritto di seguito:

  • Si Abilita la caratteristica di controllo delle versioni delle righe in un database in SQL Server 2008 R2 o in SQL Server 2008.

  • Il database viene configurato per l'uso del livello di isolamento dello snapshot.

  • È possibile eseguire molte transazioni che aggiornano contemporaneamente il database.

In questo scenario, i messaggi di errore simili a quelli seguenti vengono registrati nel file di log degli errori di SQL Server.Messaggio di errore 1

<data> <SPID> un timeout durante l'attesa per il blocco del buffer--Type 2, bp 0000003DDEFCBC80, Page 3:58642854, stat 0xc0000b, ID database: 6, ID unità di allocazione: 72057594048806912, 0x000000717CC2A748 attività: 0, waittime 300, flag 0x3a, 0x00000062F0A6CE08 attività proprietaria. Non continuare ad aspettare.

Messaggio di errore 2

<data> <SPID> timeout durante l'attesa di latch: classe "APPEND_ONLY_STORAGE_FIRST_ALLOC", ID 0000006196214E30, tipo 4, 0x000000002CA45948 attività: 0, waittime 300, flag 0x1a, 0x00000062F0533288 attività proprietaria. Continuando ad aspettare.

Messaggio di errore 3

<data> SPID #, Unknown, Error: 845<c/> gravità: 17<c/> stato: 1.

Causa

Questo problema si verifica perché la formattazione delle pagine dell'archivio versioni viene avviata dopo l'allocazione. Tuttavia, le pagine sono bloccate. Si verifica quindi un alto contenuto per le pagine.

Risoluzione

Informazioni sull'aggiornamento cumulativo

SQL Server 2008 Service Pack 3

La correzione di questo problema è stata rilasciata per la prima volta in aggiornamento cumulativo 4 per SQL Server 2008 Service Pack 3. Per altre informazioni su questo pacchetto di aggiornamento cumulativo, fare clic sul numero dell'articolo della Microsoft Knowledge Base seguente per visualizzare l'articolo:

2673383 Pacchetto di aggiornamento cumulativo 4 per SQL Server 2008 Service Pack 3Nota Poiché le build sono cumulative, ogni nuova versione di correzione contiene tutti gli hotfix e tutti gli aggiornamenti della sicurezza inclusi nella versione precedente di SQL Server 2008 FIX. Microsoft consiglia di applicare l'ultima versione di correzione che contiene questo hotfix. Per ulteriori informazioni, fare clic sul numero dell'articolo seguente per visualizzare l'articolo nella Microsoft Knowledge Base:

2629969 Build di SQL Server 2008 rilasciate dopo il rilascio di SQL Server 2008 Service Pack 3 Microsoft SQL Server 2008 hotfix vengono creati per specifici Service Pack di SQL Server. È necessario applicare un hotfix di SQL Server 2008 Service Pack 3 a un'installazione di SQL Server 2008 Service Pack 3. Per impostazione predefinita, qualsiasi hotfix fornito in un Service Pack di SQL Server è incluso nel prossimo Service Pack di SQL Server.

SQL Server 2008 R2 Service Pack 1

La correzione di questo problema è stata rilasciata per la prima volta in aggiornamento cumulativo 1 per SQL Server 2008 R2 Service Pack 1. Per altre informazioni su come ottenere questo pacchetto di aggiornamento cumulativo, fare clic sul numero dell'articolo della Microsoft Knowledge Base seguente per visualizzare l'articolo:

2544793 Pacchetto di aggiornamento cumulativo 1 per SQL Server 2008 R2 Service Pack 1Nota Poiché le build sono cumulative, ogni nuova versione di correzione contiene tutti gli hotfix e tutti gli aggiornamenti della sicurezza inclusi nella versione precedente di SQL Server 2008 R2 Fix. Ti consigliamo di considerare l'applicazione della versione di correzione più recente che contiene questo hotfix. Per ulteriori informazioni, fare clic sul numero dell'articolo seguente per visualizzare l'articolo nella Microsoft Knowledge Base:

2567616 Le build di SQL Server 2008 R2 rilasciate dopo il rilascio di SQL Server 2008 R2 Service Pack 1

SQL Server 2008 R2

La correzione di questo problema è stata rilasciata per la prima volta in aggiornamento cumulativo 8. Per altre informazioni su come ottenere questo pacchetto di aggiornamento cumulativo per SQL Server 2008 R2, fare clic sul numero dell'articolo seguente per visualizzare l'articolo della Microsoft Knowledge Base:

2534352 Pacchetto di aggiornamento cumulativo 8 per SQL Server 2008 R2 Nota Poiché le build sono cumulative, ogni nuova versione di correzione contiene tutti gli hotfix e tutti gli aggiornamenti della sicurezza inclusi nella versione precedente di SQL Server 2008 R2 Fix. Ti consigliamo di considerare l'applicazione della versione di correzione più recente che contiene questo hotfix. Per ulteriori informazioni, fare clic sul numero dell'articolo seguente per visualizzare l'articolo nella Microsoft Knowledge Base:

981356 Build di SQL Server 2008 R2 rilasciate dopo il rilascio di SQL Server 2008 R2

Stato

Microsoft ha confermato che questo problema si verifica nei prodotti elencati nella sezione "Si applica a".

Ulteriori informazioni

Questo problema potrebbe non verificarsi se si aumenta il numero di file di dati per il database tempdb per massimizzare la larghezza di banda del disco. Per ulteriori informazioni, fare clic sul numero dell'articolo seguente per visualizzare l'articolo nella Microsoft Knowledge Base:

2154845 Suggerimenti per ridurre il conflitto di allocazione nel database di SQL Server tempdb

Riferimenti

Per altre informazioni sui livelli di isolamento basati sul controllo delle versioni delle righe, visitare il sito Web MSDN seguente:

Informazioni generali sui livelli di isolamento basati sul controllo delle versioni delle righePer altre informazioni sul modello di manutenzione incrementale per SQL Server, fare clic sul numero dell'articolo della Microsoft Knowledge Base seguente per visualizzare l'articolo:

935897 Un modello di manutenzione incrementale è disponibile nel team di SQL Server per fornire gli hotfix per i problemi segnalatiPer altre informazioni sullo schema di denominazione per gli aggiornamenti di SQL Server, fare clic sul numero dell'articolo della Microsoft Knowledge Base seguente per visualizzare l'articolo:

822499Nuovo schema di denominazione per i pacchetti di aggiornamento software di Microsoft SQL ServerPer altre informazioni sulla terminologia degli aggiornamenti software, fare clic sul numero dell'articolo della Microsoft Knowledge Base seguente per visualizzare l'articolo:

824684 Descrizione della terminologia standard utilizzata per descrivere gli aggiornamenti software Microsoft

Serve aiuto?

Amplia le tue competenze
Esplora i corsi di formazione
Ottieni in anticipo le nuove caratteristiche
Partecipa a Microsoft Insider

Queste informazioni sono risultate utili?

Grazie per il feedback!

Grazie per il tuo feedback! Potrebbe essere utile metterti in contatto con uno dei nostri operatori del supporto di Office.

×