FIX: Si potrebbe verificarsi il danneggiamento dell'heap e SQL Server 2000 pu˛ chiudere con le violazioni di accesso irreversibile quando si tenta di sfogliare in SQL Server 2000 Enterprise Manager in un computer Windows Server 2003 x 64

Traduzione articoli Traduzione articoli
Identificativo articolo: 916950 - Visualizza i prodotti a cui si riferisce l?articolo.
Bug: # 40000113 (SQL Hotfix)
Microsoft distribuisce le correzioni di Microsoft SQL Server 2000 come un unico file scaricabile. PoichÚ le correzioni sono cumulative, ogni nuova versione contiene tutti gli aggiornamenti rapidi e tutte le correzioni di protezione rilasciate con SQL Server 2000 precedente versione di correzione.
Espandi tutto | Chiudi tutto

In questa pagina

Sommario

Questo articolo viene descritto il seguente su questa versione di aggiornamento rapido (hotfix):
  • I problemi risolti da questo pacchetto di aggiornamento rapido (hotfix)
  • Prerequisiti per l'installazione del pacchetto hotfix
  • Informazioni se Ŕ necessario riavviare il computer dopo l'installazione del pacchetto di aggiornamento rapido (hotfix)
  • Informazioni sulla sostituzione del pacchetto hotfix da qualsiasi altro pacchetto di aggiornamento rapido (hotfix)
  • Informazioni sulla necessitÓ di apportare le modifiche del Registro di sistema
  • I file contenuti nel pacchetto di aggiornamenti rapidi (hotfix)

Sintomi

Si consideri lo scenario seguente. Microsoft SQL Server 2000 Enterprise Manager viene eseguito in Microsoft Windows Server 2003 x 64 Edition. Si tenta di sfogliare e si fa clic sul pulsante con i puntini di sospensione (... ) nella finestra di dialogo qualsiasi file in SQL Server 2000 Enterprise Manager. In questo scenario, Ŕ possibile riscontrare danneggiamento dell'heap e SQL Server potrebbe arrestarsi con violazioni di accesso irreversibile.

Altri thread o oggetti quali componenti Microsoft oggetti Object Model (COM) potrebbero essere caricati in SQL Server utilizzando la procedura sp_oacreate memorizzati. Quando si verifica questo comportamento, OLEDB collegati provider di server che viene eseguita in-process, SQL Mail o SQLXML potrebbe essere interessato anche e causare il processo di arresto di SQL Server. Inoltre, questo problema su istanze cluster inoltre pu˛ verificarsi.

note
  • Questo problema riguarda solo le versioni a 32 bit di SQL Server 2000 in esecuzione in Windows nel sottosistema Windows 64 (WOW64) in Windows Server 2003 x 64.
  • Questo problema di danneggiamento di heap non influisce su uno qualsiasi delle versioni di SQL Server 2000 a 64 bit, ad esempio tali edizioni che vengono eseguite su IA-64 sistemi operativi che utilizzano l'architettura Intel Itanium 2.
  • Questo problema non influisce sulle edizioni a 32 bit di SQL Server presenti il sottosistema WOW64 su sistemi operativi IA-64.
  • Questo problema non riguarda tutte le edizioni di Microsoft SQL Server 2005.
Questo problema pu˛ verificarsi a causa del sistema xp_availablemedia stored procedure estesa. Quando si fa clic pulsante il con i puntini di sospensione (... ) dell'interfaccia utente grafica (GUI), il sistema di xp_availablemedia stored procedure estesa pu˛ essere chiamato l'operazione di ricerca file. Nella finestra di un'istanza cluster, Enterprise Manager chiama la routine di sp_MSSharedFixedDisk memorizzati e la routine di sp_MSSharedFixedDisk memorizzati chiama il sistema di xp_availablemedia stored procedure estesa.

╚ possibile notare il danneggiamento dell'heap non finchÚ non altri thread utilizzano l'heap predefinito o finchÚ non viene liberata memoria heap. Qualsiasi modulo che viene eseguito all'interno del processo sqlservr.exe pu˛ condividere l'heap predefinito in un processo. Di conseguenza, questo tipo di danneggiamento dell'heap pu˛ influire sui Xpstar.dll e altri moduli in cui Ŕ stato compilato il sistema di xp_availablemedia stored procedure estesa.

Per un elenco di tutti i aggiornamenti rapidi di SQL Server 2000 Service Pack rilasciati pubblicamente, vedere il seguente articolo della Microsoft Knowledge Base riportato di seguito:
894905Elenco cumulativo di aggiornamenti rapidi disponibili per SQL Server 2000 SP4

Risoluzione

Il programma di installazione non installa questo aggiornamento rapido correttamente in sistemi basati su 64 x. Questo problema di installazione si verifica quando sono vere le seguenti condizioni:
  • Il sistema utilizza l'architettura del processore Advanced Micro Devices (AMD) AMD64 o l'architettura del processore Intel Extended Memory 64 Technology (EM64T).

    Nota Questo problema non si verifica nei sistemi che utilizzano l'architettura del processore Intel Itanium.
  • Il sistema esegue una versione a 64 bit del sistema operativo Microsoft Windows Server.
  • Il sistema esegue una versione a 32 bit di SQL Server 2000.
╚ stato corretto questo problema di installazione nelle versioni successive di SQL Server 2000, a partire dalla versione 8.00.2244. Quando un cliente che esegue SQL Server 2000 su un sistema di 64 x richiede questo aggiornamento rapido (hotfix), verranno fornite una generazione che include questo aggiornamento rapido (hotfix) e che pu˛ essere installato correttamente su sistemi x 64. La build che forniamo potranno essere 8.00.2244 versione o una versione successiva.

Informazioni sull'hotfix

╚ disponibile un hotfix supportato. Questo hotfix Ŕ tuttavia destinato esclusivamente alla risoluzione del problema descritto in questo articolo. Consente di applicare questo aggiornamento rapido (hotfix) solo ai sistemi in cui si verifica questo problema specifico.

Se l'hotfix Ŕ disponibile per il download, Ŕ una sezione "Hotfix disponibile per il download" all'inizio di questo articolo della Knowledge Base. Se non viene visualizzato in questa sezione, inviare una richiesta di servizio clienti Microsoft e supporto tecnico per ottenere l'hotfix.

Nota Se si verificano ulteriori problemi o se la risoluzione dei problemi Ŕ necessario, potrebbe essere necessario creare una richiesta di servizio separato. I costi di supporto normale verranno applicati per eventuali ulteriori domande e problemi che non dovessero rientrare nello specifico hotfix in questione. Per un elenco completo, di Microsoft Customer Service and Support numeri di telefono o a creare una richiesta di servizio distinto, visitare il seguente sito Web Microsoft:
http://support.microsoft.com/contactus/?ws=support
Nota Il modulo "Hotfix disponibile per il download" Visualizza le lingue per cui Ŕ disponibile l'aggiornamento rapido. Se non viene visualizzata la lingua, Ŕ perchÚ un aggiornamento rapido (hotfix) non Ŕ disponibile per tale lingua.

Prerequisiti

╚ necessario Microsoft SQL Server 2000 Service Pack 4 (SP4) per applicare questo aggiornamento rapido (hotfix).

Per ulteriori informazioni su come ottenere SQL Server Service Pack 4, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
290211Come ottenere il service pack pi¨ recente per SQL Server 2000

Informazioni sul riavvio

Dopo aver installato questo aggiornamento rapido (hotfix), il servizio SQL Server verrÓ riavviato automaticamente.

Informazioni del Registro di sistema

Non Ŕ necessario modificare il Registro di sistema.

Informazioni sul file di hotfix

Questo aggiornamento rapido (hotfix) contiene solo i file necessari per correggere i problemi elencati nel presente articolo. Questo aggiornamento rapido (hotfix) non pu˛ contenere di tutti i file necessari per aggiornare completamente un prodotto all'ultima build.

La versione di lingua inglese di questo aggiornamento rapido (hotfix) presenta gli attributi di file (o attributi successivi) elencati nella tabella riportata di seguito. Date e ore dei file sono elencate di in ora UTC (UTC). Quando si visualizzano le informazioni sul file, viene convertito in ora locale. Per calcolare la differenza tra ora UTC e l'ora locale, utilizzare la scheda fuso orario dello data e ora nel Pannello di controllo.
SQL Server 2000 a 32 bit
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensioni fileDataOraPiattaforma
Dtsui.dll2000.80.2191.01,593,34427 Marzo 200621: 10x 86
Impprov.dll2000.80.2191.0102.40027 Marzo 200621: 10x 86
Msgprox.dll2000.80.2191.094.20827 Marzo 200621: 10x 86
Msrpjt40.dll4.10.9424.0188,47324 Gennaio 200608: 13x 86
MSSDI98.dll8.11.50523.0239,10406 / 06 / 200522: 46x 86
Ntwdblib.dll2000.80.2191.0290,81627 Marzo 200621: 10x 86
Odsole70.dll2000.80.2191.069.63227 Marzo 200621: 10x 86
Osql.exe2000.80.2191.057.34427 Marzo 200619: 25x 86
Pfclnt80.dll2000.80.2191.0430,08027 Marzo 200621: 10x 86
Replmerg.exe2000.80.2191.0163.84027 Marzo 200619: 34x 86
Replprov.dll2000.80.2191.0237.56827 Marzo 200621: 10x 86
Replrec.dll2000.80.2191.0315.39227 Marzo 200621: 10x 86
Replsub.dll2000.80.2191.0270,33627 Marzo 200621: 10x 86
Semexec.dll2000.80.2191.0856,06427 Marzo 200621: 10x 86
SQLAgent.exe2000.80.2191.0323.58427 Marzo 200619: 09x 86
Sqldiag.exe2000.80.2191.0118.78427 Marzo 200620: 15x 86
SQLDMO.dll2000.80.2191.04,362,24027 Marzo 200621: 10x 86
Sqlfth75.dll2000.80.2191.0102.40027 Marzo 200619: 23x 86
Sqlservr.exe2000.80.2191.09,162,75227 Marzo 200621: 10x 86
Sqlsort.dll2000.80.2191.0589,82427 Marzo 200621: 11x 86
Stardds.dll2000.80.2191.0176.12827 Marzo 200621: 11x 86
Svrnetcn.dll2000.80.2191.0110.59227 Marzo 200621: 11x 86
UMS.dll2000.80.2191.035.32827 Marzo 200621: 11x 86
Xpstar.dll2000.80.2191.0311.29627 Marzo 200621: 11x 86
Versione per l'architettura Itanium di SQL Server 2000
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensioni fileDataOraPiattaforma
Impprov.dll2000.80.2191.0244.73627 Marzo 200621: 14IA-64
Msgprox.dll2000.80.2191.0188.41627 Marzo 200621: 16IA-64
MSSDI98.dll8.11.50523.0758,78406 / 06 / 200522: 46IA-64
Odsole70.dll2000.80.2191.0150,52827 Marzo 200621: 13IA-64
Osql.exe2000.80.2191.0149,50427 Marzo 200621: 13IA-64
Pfclnt80.dll2000.80.2191.01,187,84027 Marzo 200621.35IA-64
Replmerg.exe2000.80.2191.0375,29627 Marzo 200621: 17IA-64
Replprov.dll2000.80.2191.0538,62427 Marzo 200621: 20IA-64
Replrec.dll2000.80.2191.0775,16827 Marzo 200621: 19IA-64
Replsub.dll2000.80.2191.0641,02427 Marzo 200621: 21IA-64
SQLAgent.exe2000.80.2191.01,061,37627 Marzo 200621: 38IA-64
Sqldiag.exe2000.80.2191.0334,33627 Marzo 200621.37IA-64
SQLDMO.dll2000.80.2191.013,860,35227 Marzo 200621: 42IA-64
Sqlfth75.dll2000.80.2191.0246,78427 Marzo 200621: 16IA-64
Sqlservr.exe2000.80.2191.024,973,31228 Marzo 200602: 22IA-64
Sqlsort.dll2000.80.2191.0617,47227 Marzo 200619: 09IA-64
Svrnetcn.dll2000.80.2191.0427,52027 Marzo 200621: 32IA-64
Xpstar.dll2000.80.2191.0873,47227 Marzo 200621: 41IA-64

Workaround

Per risolvere questo problema, si pu˛ temporaneamente impedire l'utilizzo del sistema xp_availablemedia stored procedure estesa. Per effettuare questa operazione, utilizzare il seguente esempio di codice.
use master
	go
	if exists (select * from master.dbo.sysobjects where name = N'xp_availablemedia' 
			and type = N'X')
	exec sp_dropextendedproc N'xp_availablemedia'
go
se si desidera aggiungere nuovamente il sistema di xp_availablemedia stored procedure estesa dopo avere installato l'aggiornamento rapido, utilizzare il seguente esempio di codice.
use master
	go
	sp_addextendedproc N'xp_availablemedia',N'xpstar.dll'
	go
se si rimuove la procedura, che qualsiasi chiamata alla routine sp_MSSharedFixedDisk memorizzati ha esito negativo e che qualsiasi finestra di dialogo file in SQL Server 2000 Enterprise Manager non viene visualizzata. Non viene visualizzato un messaggio di errore in Progettazione DTS. Tuttavia, non vengono visualizzate le finestre di dialogo file . Dopo aver rimosso il sistema di xp_availablemedia stored procedure estesa, Ŕ necessario digitare manualmente il nome del file o il percorso della cartella che si desidera. Inoltre, dopo che si rimuove il sistema di xp_availablemedia stored procedure estesa e si fa clic sul pulsante con i puntini di sospensione (... ) in SQL Server 2000 Enterprise Manager, riceverai il seguente messaggio di errore in un Microsoft SQL-DMO (SQLState ODBC: 42000) nella finestra di dialogo:
Errore 2812: Impossibile trovare la stored procedure 'xp_availablemedia'.
Nota Quando una delle seguenti condizioni Ŕ true, il sistema di xp_availablemedia stored procedure estesa potrebbe essere riaggiunto automaticamente a SQL Server:
  • Ripristinare il database master.
  • Si ricostruisce il database master utilizzando il Rebuildm.exe UtilitÓ.
  • Si installa un service pack o un aggiornamento rapido (hotfix).

Status

Microsoft ha confermato che questo problema riguarda i prodotti sono elencati nella sezione "Si applica a".

Informazioni

In genere, il ntdll! RtlpCoalesceFreeBlocks o ntdll! RtlFreeHeap funzioni sono le funzioni che sono vittime all'inizio di stack di thread quando si verifica di danneggiamento dell'heap nell'heap predefinito. Tuttavia, queste funzioni non sono le uniche funzioni che pu˛ interessare questo tipo di danneggiamento dell'heap. Di conseguenza, lo stack del thread di violazione di accesso per qualsiasi vittima pu˛ variare. Inoltre, Ŕ Impossibile determinare la causa del danneggiamento di heap esaminando lo stack di thread vittima singolarmente e la causa principale del danneggiamento dell'heap pu˛ dipendere da altri fattori che non sono elencati in questo articolo.

Ad esempio, una chiamata di stored procedure estesa al sistema di xp_availablemedia analoghe alle seguenti:
  • In SQL Server Enterprise Manager espandere di Server SQL , si espandere Gestione , fare clic con il pulsante destro del mouse su backup e quindi si sceglie Nuova periferica di backup .
  • Nella finestra di dialogo ProprietÓ periferica di backup - nuova periferica , si fa clic sul pulsante con i puntini di sospensione (... ) accanto al nome file per individuare un dispositivo.
Il sistema di xp_availablemedia stored procedure estesa pu˛ essere chiamato anche a livello di programmazione utilizzando SQL-DMO. Chiamare il metodo EnumAvailableMedia di un oggetto SQL Server DMO insieme con valore di parametro di SQLDMOMedia_All, SQLDMOMedia_Tape o SQLDMOMedia_SharedFixedDisk MediaType . Indipendentemente da come si utilizza la procedura, il risultato sempre pu˛ essere lo stesso.

Per ulteriori informazioni, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
824684Descrizione della terminologia standard utilizzata per descrivere gli aggiornamenti software Microsoft

ProprietÓ

Identificativo articolo: 916950 - Ultima modifica: venerdý 2 novembre 2007 - Revisione: 1.9
Le informazioni in questo articolo si applicano a:
  • Microsoft SQL Server 2000 Developer Edition
  • Microsoft SQL Server 2000 Enterprise Edition
  • Microsoft SQL Server 2000 Personal Edition
  • Microsoft SQL Server 2000 Standard Editionáalle seguenti piattaforme
    • Microsoft Windows Server 2003, Standard x64 Edition
    • Microsoft Windows Server 2003, Enterprise x64 Edition
Chiavi:á
kbmt kbautohotfix kbbug kbhotfixserver kbqfe KB916950 KbMtit
Traduzione automatica articoli
Il presente articolo Ŕ stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell?utente. Tuttavia, un articolo tradotto in modo automatico non Ŕ sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, pi¨ o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non Ŕ la sua. Microsoft non Ŕ responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell?utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.
Clicca qui per visualizzare la versione originale in inglese dell?articolo: 916950
LE INFORMAZIONI CONTENUTE NELLA MICROSOFT KNOWLEDGE BASE SONO FORNITE SENZA GARANZIA DI ALCUN TIPO, IMPLICITA OD ESPLICITA, COMPRESA QUELLA RIGUARDO ALLA COMMERCIALIZZAZIONE E/O COMPATIBILITA' IN IMPIEGHI PARTICOLARI. L'UTENTE SI ASSUME L'INTERA RESPONSABILITA' PER L'UTILIZZO DI QUESTE INFORMAZIONI. IN NESSUN CASO MICROSOFT CORPORATION E I SUOI FORNITORI SI RENDONO RESPONSABILI PER DANNI DIRETTI, INDIRETTI O ACCIDENTALI CHE POSSANO PROVOCARE PERDITA DI DENARO O DI DATI, ANCHE SE MICROSOFT O I SUOI FORNITORI FOSSERO STATI AVVISATI. IL DOCUMENTO PUO' ESSERE COPIATO E DISTRIBUITO ALLE SEGUENTI CONDIZIONI: 1) IL TESTO DEVE ESSERE COPIATO INTEGRALMENTE E TUTTE LE PAGINE DEVONO ESSERE INCLUSE. 2) I PROGRAMMI SE PRESENTI, DEVONO ESSERE COPIATI SENZA MODIFICHE, 3) IL DOCUMENTO DEVE ESSERE DISTRIBUITO INTERAMENTE IN OGNI SUA PARTE. 4) IL DOCUMENTO NON PUO' ESSERE DISTRIBUITO A SCOPO DI LUCRO.

Invia suggerimenti

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com