Problemi noti, limitazioni e passaggi per la risoluzione dei problemi
Questo articolo fornisce un elenco dei problemi noti e dei passaggi di risoluzione dei problemi associati all'estensione Migrazione SQL di Azure per Azure Data Studio.
Importante
La versione più recente di Integration Runtime (5.28.8488) impedisce l'accesso a una condivisione file di rete in un host locale. Questa misura di sicurezza causerà errori durante l'esecuzione delle migrazioni ad Azure SQL tramite Servizio Migrazione del database. Assicurarsi di eseguire Integration Runtime in un computer differente dall'hosting della condivisione di rete.
Codice errore: 2007 - CutoverFailedOrCancelled
Messaggio:
Cutover failed or cancelled for database <DatabaseName>. Error details: The restore plan is broken because firstLsn <First LSN> of log backup <URL of backup in Azure Storage container>' is not <= lastLsn <last LSN> of Full backup <URL of backup in Azure Storage container>'. Restore to point in time.
Causa: l'errore può verificarsi a causa dei backup inseriti in modo non corretto nel contenitore di Archiviazione di Azure. Se i backup vengono inseriti nella condivisione file di rete, questo errore potrebbe verificarsi anche a causa di problemi di connettività di rete.
Raccomandazione: assicurarsi che i backup del database nel contenitore di Archiviazione di Azure siano corretti. Se si usa la condivisione file di rete, possono verificarsi problemi e ritardi correlati alla rete che causano questo errore. Attendi che il processo venga completato.
Messaggio:
Cutover failed or cancelled for database '{databaseName}'. Error details: 'errorCode: Ext_RestoreSettingsError, message: RestoreId: {RestoreId}, OperationId: {operationId}, Detail: Failed to complete restore., RestoreJobState: Restoring, CompleteRestoreErrorMessage: The database contains incompatible physical layout. Too many full text catalog files.
Causa: il ripristino di SQL VM non supporta attualmente il ripristino di database con file di catalogo full text, poiché la VM di Azure SQL al momento non li supporta.
Raccomandazione: rimuovere i file di catalogo full-text dal database durante la creazione del ripristino
Messaggio:
Cutover failed or cancelled for database '{databaseName}'. Error details: 'Migration cannot be completed because provided backup file name '{providedFileName}' should be the last restore backup file '{lastRestoredFileName}'.'
Causa: questo errore si verifica a causa di una limitazione nota in SqlMi. Significa che '{providedFileName}' è differente da '{lastRestoredFileName}'. SqlMi ripristinerà automaticamente tutti i file di backup validi nel contenitore in base alla sequenza LSN. Un caso di errore tipico può essere: '{providedFileName}' è "log1", ma i file nel contenitore hanno altri file, ad esempio "log2", con numero LSN maggiore di "log1". In questo caso, SqlMi ripristinerà automaticamente tutti i file nel contenitore. Al termine del completamento della migrazione, SqlMi segnala questo messaggio di errore.
Raccomandazione: per la modalità di migrazione offline, specificare "lastBackupName" con il numero LSN più grande. Per lo scenario di migrazione online, questo avviso o errore può essere ignorato se lo stato della migrazione è riuscito.
Codice errore: 2009 - MigrationRestoreFailed
Messaggio:
Migration for Database 'DatabaseName' failed with error cannot find server certificate with thumbprint.
Causa: prima di eseguire la migrazione dei dati, è necessario eseguire la migrazione del certificato dell'istanza di SQL Server di origine da un database protetto da Transparent Data Encryption (TDE) all'Istanza gestita di SQL di Azure di destinazione o a SQL Server nella macchina virtuale di Azure.
Raccomandazione: eseguire la migrazione del certificato TDE all'istanza di destinazione e ripetere il processo. Per altre informazioni sulla migrazione di database abilitati per TDE, vedere Esercitazione: eseguire la migrazione di database abilitati per TDE (anteprima) ad Azure SQL in Azure Data Studio.
Messaggio:
Migration for Database <DatabaseName> failed with error 'Non retriable error occurred while restoring backup with index 1 - 3169 The database was backed up on a server running version %ls. That version is incompatible with this server, which is running version %ls. Either restore the database on a server that supports the backup, or use a backup that is compatible with this server.
Causa: impossibile ripristinare un backup di SQL Server in una versione precedente di SQL Server rispetto alla versione in cui è stato creato il backup.
Raccomandazione: vedere Problemi che influiscono sul ripristino del database tra diverse versioni di SQL Server per la procedura di risoluzione dei problemi.
Messaggio:
Migration for Database <DatabaseName> failed with error 'The managed instance has reached its storage limit. The storage usage for the managed instance can't exceed 32768 MBs.
Causa: l'Istanza gestita di SQL di Azure ha raggiunto i limiti delle risorse.
Raccomandazione: per altre informazioni sui limiti di archiviazione, vedere Panoramica dei limiti delle risorse di Istanza gestita di SQL di Azure.
Messaggio:
Migration for Database <DatabaseName> failed with error 'Non retriable error occurred while restoring backup with index 1 - 3634 The operating system returned the error '1450(Insufficient system resources exist to complete the requested service.)
Causa: uno dei sintomi elencati in Segnalati errori del sistema operativo 1450 e 665 per i file di database durante la creazione di database DBCC CHECKDB o snapshot del database può essere la causa.
Raccomandazione: vedere Segnalati errori del sistema operativo 1450 e 665 per i file di database la creazione di DBCC CHECKDB o snapshot del database per la procedura di risoluzione dei problemi.
Messaggio:
The restore plan is broken because firstLsn <First LSN> of log backup <URL of backup in Azure Storage container>' isn't <= lastLsn <last LSN> of Full backup <URL of backup in Azure Storage container>'. Restore to point in time.
Causa: l'errore può verificarsi a causa dei backup inseriti in modo non corretto nel contenitore di Archiviazione di Azure. Se i backup vengono inseriti nella condivisione file di rete, questo errore potrebbe verificarsi anche a causa di problemi di connettività di rete.
Raccomandazione: assicurarsi che i backup del database nel contenitore di Archiviazione di Azure siano corretti. Se si usa la condivisione file di rete, possono verificarsi problemi di rete e ritardi che causano questo errore. Attendere il completamento del processo.
Messaggio:
Migration for Database <Database Name> failed with error 'Non retriable error occurred while restoring backup with index 1 - 3234 Logical file <Name> isn't part of database <Database GUID>. Use RESTORE FILELISTONLY to list the logical file names. RESTORE DATABASE is terminating abnormally.'.
Causa: è stato specificato un nome di file logico non incluso nel backup del database. Un'altra possibile causa di questo errore è un nome di contenitore dell'account di archiviazione non corretto.
Raccomandazione: eseguire RESTORE FILELISTONLY per controllare i nomi di file logici nel backup. Per altre informazioni su RESTORE FILELISTONLY, vedere Istruzioni RESTORE - FILELISTONLY (Transact-SQL).
Messaggio:
Migration for Database <Database Name> failed with error 'Azure SQL target resource failed to connect to storage account. Make sure the target SQL VNet is allowed under the Azure Storage firewall rules.'
Causa: il firewall di Archiviazione di Azure non è configurato per consentire l'accesso alla destinazione SQL di Azure.
Raccomandazione: per altre informazioni sulla configurazione del firewall di Archiviazione di Azure, vedere Configurare firewall e reti virtuali di Archiviazione di Azure.
Messaggio:
Migration for Database <Database Name> failed with error 'There are backups from multiple databases in the container folder. Please make sure the container folder has backups from a single database.
Causa: i backup di più database si trovano nella stessa cartella contenitore.
Raccomandazione: se si esegue la migrazione di vari database a Istanza gestita di SQL di Azure usando lo stesso contenitore Archivio BLOB di Azure, è necessario inserire i file di backup per database differenti in cartelle separate all'interno del contenitore. Per altre informazioni sull'archiviazione con ridondanza locale, vedere Eseguire la migrazione di database da SQL Server a Istanza gestita di SQL usando il servizio di riproduzione log (anteprima).
Messaggio:
Migration for Database <Database Name> failed with error 'Non retriable error occurred while restoring backup with index 1 - 12824 The sp_configure value 'contained database authentication' must be set to 1 in order to restore a contained database. You may need to use RECONFIGURE to set the value_in_use. RESTORE DATABASE is terminating abnormally.
Causa: il database di origine è un database indipendente. È necessaria una configurazione specifica per abilitare il ripristino di un database indipendente. Per altre informazioni sui database indipendenti, vedere Utenti di database indipendenti.
Raccomandazione: eseguire la query seguente connessa all'istanza di SQL Server di origine nel contesto del database specifico prima di avviare la migrazione. Quindi, tentare di nuovo la migrazione del database indipendente.
-- Enable "contained database authentication" EXECUTE sp_configure 'contained', 1; RECONFIGURE;
Nota
Per altre informazioni sui passaggi generali per la risoluzione dei problemi relativi agli errori di Istanza gestita di SQL di Azure, vedere Problemi noti con Istanza gestita di SQL di Azure
Codice errore: 2012 - TestConnectionFailed
Messaggio:
Failed to test connections using provided Integration Runtime. Error details: 'Remote name could not be resolved.'
Causa: le impostazioni di rete nel firewall causano l'impossibilità di connettersi al back-end del servizio dal runtime di integrazione self-hosted.
Raccomandazione: si è verificato un problema Domain Name System (DNS). Per risolvere il problema, contattare il team addetto alla rete. Per altre informazioni, vedere Risolvere i problemi relativi al runtime di integrazione self-hosted.
Messaggio:
Failed to test connections using provided Integration Runtime. 'Cannot connect to <File share>. Detail Message: The system could not find the environment option that was entered
Causa: il runtime di integrazione self-hosted non è in grado di connettersi alla condivisione file di rete in cui vengono inseriti i backup del database.
Raccomandazione: assicurarsi che il nome della condivisione file di rete sia immesso correttamente.
Messaggio:
Failed to test connections using provided Integration Runtime. The file name does not conform to the naming rules by the data store. Illegal characters in path.
Causa: il runtime di integrazione self-hosted non è in grado di connettersi alla condivisione file di rete in cui vengono inseriti i backup del database.
Raccomandazione: assicurarsi che il nome della condivisione file di rete sia immesso correttamente.
Messaggio:
Failed to test connections using provided Integration Runtime.
Causa: la connessione al runtime di integrazione self-hosted non è riuscita.
Raccomandazione: vedere Risolvere i problemi relativi al runtime di integrazione self-hosted per i passaggi generali per la risoluzione dei problemi relativi agli errori di connettività del runtime di integrazione.
Codice errore: 2014 - IntegrationRuntimeIsNotOnline
Messaggio:
Integration Runtime <IR Name> in resource group <Resource Group Name> Subscription <SubscriptionID> isn't online.
Causa: il runtime di integrazione self-hosted non è online.
Raccomandazione: assicurarsi che il runtime di integrazione self-hosted sia registrato e online. Per eseguire la registrazione, è possibile usare gli script di Automazione dell'installazione del runtime di integrazione self-hosted usando script di PowerShell locali. Vedere anche Risolvere i problemi relativi al runtime di integrazione self-hosted per i passaggi generali per la risoluzione dei problemi relativi agli errori di connettività del runtime di integrazione.
Codice errore: 2030 - AzureSQLManagedInstanceNotReady
Messaggio:
Azure SQL Managed Instance <Instance Name> isn't ready.
Causa: Istanza gestita di SQL di Azure non in stato pronto.
Raccomandazione: attendere che l'Istanza gestita di SQL di Azure abbia terminato la distribuzione e sia pronta, quindi ripetere il processo.
Codice errore: 2033 - SqlDataCopyFailed
Messaggio:
Migration for Database <Database> failed in state <state>.
Causa: pipeline di ADF per lo spostamento dei dati non riuscita.
Raccomandazione: per informazioni più dettagliate sull'errore, vedere la pagina MigrationStatusDetails.
Codice errore: 2038 - MigrationCompletedDuringCancel
Messaggio:
Migration cannot be canceled as Migration was completed during the cancel process. Target server: <Target server> Target database: <Target database>.
Causa: è stata ricevuta una richiesta di annullamento, ma la migrazione è stata completata correttamente prima del completamento dell'annullamento.
Raccomandazione: nessuna azione necessaria. Migrazione riuscita.
Codice errore: 2039 - MigrationRetryNotAllowed
Messaggio:
Migration isn't in a retriable state. Migration must be in state WaitForRetry. Current state: <State>, Target server: <Target Server>, Target database: <Target database>.
Causa: è stata ricevuta una richiesta di ripetizione dei tentativi quando la migrazione non era in uno stato che consente di riprovare.
Raccomandazione: nessuna azione necessaria. La migrazione è in corso o completata.
Codice errore: 2040 - MigrationTimeoutWaitingForRetry
Messaggio:
Migration retry timeout limit of 8 hours reached. Target server: <Target Server>, Target database: <Target Database>.
Causa: la migrazione è inattiva in uno stato di inattività, ma lo stato recuperabile per 8 ore è stato annullato automaticamente.
Raccomandazione: non è necessaria alcuna azione. La migrazione è stata annullata.
Codice errore: 2041 - DataCopyCompletedDuringCancel
Messaggio:
Data copy finished successfully before canceling completed. Target schema is in bad state. Target server: <Target Server>, Target database: <Target Database>.
Causa: la richiesta di annullamento è stata ricevuta e la copia dei dati è stata completata correttamente, ma lo schema del database di destinazione non è stato restituito allo stato originale.
Raccomandazione: se lo si desidera, il database di destinazione può essere restituito allo stato originale eseguendo la prima query e tutte le query restituite, quindi eseguendo la seconda query ed eseguendo la stessa operazione.
SELECT [ROLLBACK] FROM [dbo].[__migration_status] WHERE STEP IN (3, 4, 6); SELECT [ROLLBACK] FROM [dbo].[__migration_status] WHERE STEP IN (5, 7, 8) ORDER BY STEP DESC;
Codice errore: 2042 - PreCopyStepsCompletedDuringCancel
Messaggio:
Pre Copy steps finished successfully before canceling completed. Target database Foreign keys and temporal tables have been altered. Schema migration may be required again for future migrations. Target server: <Target Server>, Target database: <Target Database>.
Causa: la richiesta di annullamento è stata ricevuta e i passaggi per preparare il database di destinazione per la copia sono stati completati correttamente. Lo schema del database di destinazione non è stato restituito allo stato originale.
Raccomandazione: se lo si desidera, il database di destinazione può essere restituito allo stato originale eseguendo la query seguente e tutte le query restituite.
SELECT [ROLLBACK] FROM [dbo].[__migration_status] WHERE STEP IN (3, 4, 6);
Codice errore: 2043 - CreateContainerFailed
Messaggio:
Create container <ContainerName> failed with error Error calling the endpoint '<URL>'. Response status code: 'NA - Unknown'. More details: Exception message: 'NA - Unknown [ClientSideException] Invalid Url:<URL>.
Causa: la richiesta non è andata a buon fine a causa di un problema sottostante relativo, ad esempio, alla connettività di rete, a un errore DNS, alla convalida del certificato del server o a un timeout.
Raccomandazione: per altre procedure di risoluzione dei problemi, vedere Risolvere i problemi relativi alle pipeline di Azure Data Factory e Synapse.
Codice errore: 2049 - FileShareTestConnectionFailed
Messaggio:
The value of the property '' is invalid: 'Access to <share path> is denied, resolved IP address is <IP address>, network type is OnPremise'.
Causa: la condivisione di rete in cui vengono archiviati i backup del database si trova nello stesso computer del runtime di integrazione self-hosted (SHIR).
Raccomandazione: la versione più recente di Integration Runtime (5.28.8488) impedisce l'accesso a una condivisione file di rete in un host locale. Assicurarsi di eseguire Integration Runtime in un computer differente dall'hosting della condivisione di rete. Se l'hosting del runtime di integrazione self-hosted e della condivisione di rete in computer differenti non è possibile con la configurazione di migrazione corrente, è possibile usare l'opzione per rifiutare esplicitamente l'uso di
DisableLocalFolderPathValidation
.Nota
Per altre informazioni, vedere Configurare un runtime di integrazione self-hosted esistente tramite PowerShell locale. Usare l'opzione di disabilitazione con discrezione perché questa opzione è meno sicura.
Codice errore: 2055 - SqlInfoCollectionFailed
Messaggio:
A database operation failed with the following error: 'VIEW SERVER PERFORMANCE STATE permission was denied on object 'server', database 'master'. The user does not have permission to perform this action.
Causa: l'account di accesso usato per il server di destinazione (database Azure SQL) non ha il ruolo del server ###MS_ServerStateReader##.
Raccomandazione: fornire il ruolo ##MS_ServerStateReader## all'account di accesso per la destinazione SQL di Azure. Query: ALTER SERVER ROLE ##MS_ServerStateReader## ADD MEMBER login.Query: ALTER SERVER ROLE ##MS_ServerStateReader## ADD MEMBER login.
Nota: questa query deve essere eseguita nel contesto del database master
Codice errore: 2056 - SqlInfoValidationFailed
Messaggio:
CollationMismatch: Source database collation <CollationOptionSource> is not the same as the target database <CollationOptionTarget>. Source database: <SourceDatabaseName> Target database: <TargetDatabaseName>.
Causa: le regole di confronto del database di origine non corrispondono alle regole di confronto del database di destinazione.
Raccomandazione: assicurarsi di modificare le regole di confronto del Database SQL di Azure di destinazione allo stesso modo del database SQL Server di origine. Il Database SQL di Azure usa le regole di confronto
SQL_Latin1_General_CP1_CI_AS
per impostazione predefinita, nel caso in cui il database di SQL Server di origine usi regole di confronto diverse, potrebbe essere necessario ricreare o selezionare un database di destinazione differente le cui corrispondenze con le regole di confronto. Per altre informazioni, vedere Supporto regole di confronto e UnicodeMessaggio:
TableColumnCollationMismatch: Table <Tablename> with column <columnname> has collation <collationoptionsource> on source but has collation <collationoptiontarget> on target table.
Causa: le regole di confronto della colonna della tabella di database di origine non corrispondono alle regole di confronto della colonna della tabella di database di destinazione.
Raccomandazione:
Assicurarsi di eseguire la migrazione dello schema al Database SQL di Azure di destinazione usando il Servizio Migrazione del database. Fare riferimento al blog.
Seguire questo articolo per modificare manualmente le regole di confronto.
Per altre informazioni, vedere Supporto regole di confronto e Unicode
Messaggio:
DatabaseSizeMoreThanMax: No tables were found in the target Azure SQL Database. Check if schema migration was completed beforehand.
Causa: le tabelle selezionate per la migrazione non sono presenti nel Database SQL di Azure di destinazione.
Raccomandazione: assicurarsi che lo schema del database di destinazione sia stato creato prima di avviare la migrazione. Per altre informazioni su come distribuire lo schema del database di destinazione, vedere Estensione Progetti di database SQL
Messaggio:
DatabaseSizeMoreThanMax: The source database size <Source Database Size> exceeds the maximum allowed size of the target database <Target Database Size>. Check if the target database has enough space.
Causa: il database di destinazione non dispone di spazio sufficiente.
Raccomandazione: assicurarsi che lo schema del database di destinazione sia stato creato prima di avviare la migrazione. Per altre informazioni su come distribuire lo schema del database di destinazione, vedere Estensione Progetti di database SQL.
Messaggio:
NoTablesFound: Some of the source tables don't exist in the target database. Missing tables: <TableList>
.Causa: le tabelle selezionate per la migrazione non sono presenti nel Database SQL di Azure di destinazione.
Raccomandazione: controllare se le tabelle selezionate esistono nel Database SQL di Azure di destinazione. Se questa migrazione viene chiamata da uno script di PowerShell, verificare se il parametro dell'elenco di tabelle include i nomi di tabella corretti e viene passato alla migrazione.
Messaggio:
SqlVersionOutOfRange: Source instance version is lower than 2008, which is not supported to migrate. Source instance: <InstanceName>
.Causa: Servizio Migrazione del database di Azure non supporta la migrazione da istanze di SQL Server inferiori al 2008.
Raccomandazione: aggiornare l'istanza di SQL Server di origine a una versione più recente di SQL Server. Per altre informazioni, vedere Aggiornare SQL Server.
Messaggio:
TableMappingMismatch: Some of the source tables don't exist in the target database. Missing tables: <TableList>
.Causa: le tabelle selezionate per la migrazione non sono presenti nel Database SQL di Azure di destinazione.
Raccomandazione: controllare se le tabelle selezionate esistono nel Database SQL di Azure di destinazione. Se questa migrazione viene chiamata da uno script di PowerShell, verificare se il parametro dell'elenco di tabelle include i nomi di tabella corretti e viene passato alla migrazione.
Codice errore: 2060 - SqlSchemaCopyFailed
Messaggio:
The SELECT permission was denied on the object 'sql_logins', database 'master', schema 'sys'.
Causa: l'account usato dai clienti per connettersi al Database SQL di Azure non dispone dell'autorizzazione per accedere
sys.sql_logins
alla tabella.Raccomandazione: esistono due modi per attenuare il problema:
Aggiungere il ruolo "amministratore di sistema" all'account, che concede l'autorizzazione di amministratore.
Se i clienti non possono usare l'account amministratore di sistema o non possono concedere l'autorizzazione amministratore di sistema all'account, l'autorizzazione minima necessaria per SQL Server di origine è "db_owner" e nel Database SQL di Azure di destinazione creare un utente nel master e concedere i ruoli server fissi ##MS_DatabaseManager#,##MS_DatabaseConnector#, ##MS_DefinitionReader## e ##MS_LoginManager## all'utente. ad esempio:
-- Run the script in the master database CREATE LOGIN testuser WITH PASSWORD = '*********'; ALTER SERVER ROLE ##MS_DefinitionReader## ADD MEMBER [testuser]; GO ALTER SERVER ROLE ##MS_DatabaseConnector## ADD MEMBER [testuser]; GO ALTER SERVER ROLE ##MS_DatabaseManager## ADD MEMBER [testuser]; GO ALTER SERVER ROLE ##MS_LoginManager## ADD MEMBER [testuser]; GO CREATE USER testuser FOR LOGIN testuser; EXECUTE sp_addRoleMember 'dbmanager', 'testuser'; EXECUTE sp_addRoleMember 'loginmanager', 'testuser';
Messaggio:
Failed to get service token from ADF service.
Causa: il servizio SHIR del cliente non riesce a connettersi a Data Factory.
Raccomandazione: questo è un documento di esempio su come risolverlo: Integration Runtime non è in grado di connettersi a Data Factory
Messaggio:
IR Nodes are offline.
Causa: la causa potrebbe essere che la rete viene interrotta durante la migrazione per cui il nodo del runtime di integrazione diventa offline. Assicurarsi che il computer in cui è installato SHIR sia attivo.
Raccomandazione: assicurarsi che il computer in cui è installato SHIR sia attivo.
Messaggio:
Deployed failure: {0}. Object element: {1}.
Causa: questo è l'errore più comune che i clienti potrebbero riscontrare. Significa che l'oggetto non può essere distribuito nella destinazione perché non è supportato nella destinazione.
raccomandazione: i clienti devono controllare i risultati della valutazione (regole di valutazione). Questo è l'elenco dei problemi di valutazione che potrebbero non riuscire nella migrazione dello schema:
- BULK INSERT
- COMPUTE - clausola
- Provider del servizio di crittografia
- Riferimenti tra database
- Alias entità di sicurezza database
- Opzione DISABLE_DEF_CNST_CHK
- Hint FASTFIRSTROW
- FILESTREAM
- MS DTC
- OPENROWSET (bulk)
- OPENROWSET (provider)
Nota
Per visualizzare i dettagli degli errori, aprire Gestione configurazione di Microsoft Integration Runtime e andare a Diagnostica> Registrazione > Visualizza log. Nel Visualizzatore eventi andare a Log applicazioni e servizi > Connettori - Runtime di integrazione e filtrare gli errori.
Messaggio:
Deployed failure: Index cannot be created on computed column '{0}' of table '{1}' because the underlying object '{2}' has a different owner. Object element: {3}.
Script generato di esempio:
IF NOT EXISTS (SELECT * FROM sys.indexes WHERE object_id = OBJECT_ID(N'[Sales].[Customer]') AND name = N'AK_Customer_AccountNumber') CREATE UNIQUE NONCLUSTERED INDEX [AK_Customer_AccountNumber] ON [Sales].[Customer] ( [AccountNumber] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
Causa: Tutti i riferimenti a funzioni nella colonna calcolata devono avere lo stesso proprietario della tabella.
Raccomandazione: vedere Requisiti di proprietà.
Codice errore: Ext_RestoreSettingsError
Messaggio:
Unable to read blobs in storage container, exception: The remote server returned an error: (403) Forbidden.; The remote server returned an error: (403) Forbidden
Causa: la destinazione SQL di Azure non è in grado di connettersi all'archivio BLOB.
Raccomandazione: verificare che le impostazioni di rete di destinazione consentano l'accesso all'archiviazione BLOB. Ad esempio, se si esegue la migrazione a un'istanza di SQL Server nella destinazione della VM di Azure, assicurarsi che le connessioni in uscita nella VM non vengano bloccate.
Messaggio:
Failed to create restore job. Unable to read blobs in storage container, exception: The remote name could not be resolved.
Causa: la destinazione SQL di Azure non è in grado di connettersi all'archivio BLOB.
Raccomandazione: verificare che le impostazioni di rete di destinazione consentano l'accesso all'archiviazione BLOB. Ad esempio, se si esegue la migrazione alla VM SQL, assicurarsi che le connessioni in uscita nella VM non vengano bloccate.
Messaggio:
Migration for Database <Database Name> failed with error 'Migration cannot be completed because provided backup file name <Backup File Name> should be the last restore backup file <Last Restore Backup File Name>'
.Causa: il backup più recente non è stato specificato nelle impostazioni di backup.
Raccomandazione: specificare il nome del file di backup più recente nelle impostazioni di backup e ripetere l'operazione.
Messaggio:
Operation failed: errorCode: Ext_RestoreSettingsError, message: RestoreId: 1111111-aaaa-bbbb-cccc-dddddddd, OperationId: 2222222-aaaa-bbbb-cccc-dddddddd, Detail: Unable to read blobs in storage container, exception: Unable to connect to the remote server;Unable to connect to the remote server;A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond 11.111.11.111:443.
Causa: è possibile che si verifichi l'errore per entrambi gli account di archiviazione con la rete pubblica e la configurazione dell'endpoint privato. È anche possibile avere un server DNS locale che controlla un routing di rete ibrido e DHCP. A meno che non si consentano gli indirizzi IP di Azure configurati nel server DNS, SQL Server nella destinazione della VM di Azure non ha la possibilità di risolvere l'endpoint BLOB di archiviazione remota.
Raccomandazione: per eseguire il debug di questo problema, è possibile provare a eseguire il ping dell'URL di Archiviazione BLOB di Azure dall'istanza di SQL Server nella destinazione della VM di Azure e verificare se si è verificato un problema di connettività. Per risolvere questo problema, è necessario consentire gli indirizzi IP di Azure configurati nel server DNS. Per altre informazioni, vedere Risolvere i problemi di connettività dell'endpoint privato di Azure
Codice errore: non si conosce alcun host di questo tipo, O errore urlopen [Errno 11001] getaddrinfo non riuscito
Messaggio:
No such host is known
Causa: durante la migrazione degli account di accesso con il comando PowerShell New-AzDataMigrationLoginsMigration, l'operazione ha esito negativo con il messaggio precedente.
Raccomandazione: per risolvere questo problema, aggiornare i cmdlet di Microsoft Azure PowerShell - Servizio Migrazione del database - Az.DataMigration oltre la versione minima 0.14.5.
È possibile scaricare la versione più recente di Az.Datamigration dalla raccolta di PowerShell o usare il comando seguente per eseguire l'aggiornamento.
Update-Module -Name Az.DataMigration
Messaggio:
urlopen error [Errno 11001] getaddrinfo failed
Causa: durante la migrazione degli account di accesso con l'interfaccia della riga di comando di Azure Az dataMigration login-migration, l'operazione ha esito negativo con il messaggio precedente.
Raccomandazione: per risolvere questo problema, aggiornare l'estensione dell'interfaccia della riga di comando di Microsoft Azure - Servizio Migrazione del database - az dataMigration alla versione 1.0.0b1 o successiva. Eseguire il comando seguente per eseguire l'aggiornamento.
az extension update -n datamigration
Regole di denominazione del Servizio Migrazione del database di Azure
Se il Servizio Migrazione del database non è riuscito con "Errore: il nome del servizio 'x_y_z' non è valido", è necessario seguire le regole di denominazione del Servizio Migrazione del database di Azure. Poiché il Servizio Migrazione del database di Azure usa Azure Data Factory per il calcolo, segue le stesse regole indicate nelle regole di denominazione.
Limitazioni del Database SQL di Azure
La migrazione a Database SQL di Azure usando l'estensione Azure SQL per Azure Data Studio presenta le limitazioni seguenti:
La migrazione offline di Azure SQL Database utilizza le pipeline di Azure Data Factory (ADF) per lo spostamento dei dati e quindi rispetta le limitazioni di Azure Data Factory. Quando viene creato anche un servizio di migrazione del database, viene creato un Azure Data Factory corrispondente. Di conseguenza, i limiti di factory si applicano per servizio.
- Il computer in cui è installato SHIR funge da calcolo per la migrazione. Assicurarsi che questo computer possa gestire il carico di cpu e memoria della copia dei dati. Per altre informazioni, vedere Consigli di SHIR.
- 100.000 tabelle per limite di database.
- 10.000 migrazioni simultanee di database per servizio.
- La velocità di migrazione dipende in larga parte dall'SKU del database SQL di Azure di destinazione e dall'host del runtime di integrazione self-hosted.
- Nel database SQL di Azure, la migrazione si dimensiona in modo non appropriato con i numeri di tabella a causa del sovraccarico di Azure Data Factory nelle attività iniziali. Se un database ha migliaia di tabelle, il processo di avvio di ciascuna tabella potrebbe richiedere un paio di secondi, anche se sono composti da una riga con 1 bit di dati.
- Il database SQL di Azure non supporta la migrazione di nomi di tabella contenenti caratteri a byte doppio. La mitigazione consiste nel rinominare le tabelle prima della migrazione; possono essere nuovamente modificate con i nomi originali a migrazione correttamente avvenuta.
- Le tabelle con colonne BLOB di grandi dimensioni possono non riuscire nella migrazione a causa del timeout.
- I nomi di database con SQL Server prenotati non sono attualmente supportati.
- I nomi di database che includono punti e virgola non sono attualmente supportati.
- Le colonne calcolate non vengono migrate.
Limitazioni dell'Istanza gestita di SQL di Azure
La migrazione a Istanza gestita di SQL di Azure usando l'estensione Azure SQL per Azure Data Studio presenta le limitazioni seguenti:
- Se si esegue la migrazione di un database singolo, i backup del database devono essere inseriti in una struttura di file flat all'interno di una cartella di database (inclusa la cartella radice del contenitore) e le cartelle non possono essere annidate, perché l'annidamento non è supportato.
- Se si esegue la migrazione di più database usando lo stesso contenitore Archivio BLOB di Azure, è necessario inserire i file di backup per database diversi in cartelle separate all'interno del contenitore.
- La sovrascrittura dei database esistenti tramite Servizio Migrazione del database nell'Istanza gestita di SQL di Azure di destinazione non è supportata.
- Il Servizio Migrazione del database non supporta la configurazione della disponibilità elevata e del ripristino di emergenza nella destinazione in modo che corrisponda alla topologia di origine.
- Gli oggetti server seguenti non sono supportati:
- SQL Server Agent - processi
- Credenziali
- Pacchetti SSIS
- Controllo server
- Non è possibile usare un runtime di integrazione self-hosted esistente creato da Azure Data Factory per le migrazioni di database con Servizio Migrazione del database. Inizialmente, il runtime di integrazione self-hosted deve essere creato usando l'estensione di migrazione Azure SQL in Azure Data Studio e può essere riutilizzato per altre migrazioni di database.
- Un singolo processo di archiviazione con ridondanza locale (creato dal Servizio Migrazione del database) può essere eseguito per un massimo di 30 giorni. Alla scadenza di questo periodo, il processo viene annullato automaticamente, in modo che il database di destinazione venga eliminato automaticamente.
- Se si ha ricevuto il messaggio di errore seguente:
Memory-optimized filegroup must be empty in order to be restored on General Purpose tier of SQL Database Managed Instance
. Questo problema è per impostazione predefinita, Hekaton (noto anche come OLTP in memoria di SQL Server) non è supportato nel livello Utilizzo generico di Istanza gestita di SQL di Azure. Per continuare la migrazione, un modo consiste nell'eseguire l'aggiornamento al livello Business Critical, che supporta Hekaton. Un altro modo consiste nel assicurarsi che il database di origine non lo usi quando l’Istanza gestita di SQL di Azure è un utilizzo generico.
Limitazioni di SQL Server nelle VM di Azure
La migrazione a SQL Server nelle VM Azure tramite l'estensione Azure SQL per Azure Data Studio presenta le limitazioni seguenti:
- Se si esegue la migrazione di un database singolo, i backup del database devono essere inseriti in una struttura di file flat all'interno di una cartella di database (inclusa la cartella radice del contenitore) e le cartelle non possono essere annidate, perché l'annidamento non è supportato.
- Se si esegue la migrazione di più database usando lo stesso contenitore Archivio BLOB di Azure, è necessario inserire i file di backup per database diversi in cartelle separate all'interno del contenitore.
- La sovrascrittura dei database esistenti tramite il Servizio Migrazione del database nell’SQL Azure di destinazione su Macchina virtuale di Azure non è supportata.
- La configurazione della disponibilità elevata e del ripristino di emergenza nella destinazione in modo che corrisponda alla topologia di origine non è supportata dal Servizio Migrazione del database.
- Gli oggetti server seguenti non sono supportati:
- SQL Server Agent - processi
- Credenziali
- Pacchetti SSIS
- Controllo server
- Non è possibile usare un runtime di integrazione self-hosted esistente creato da Azure Data Factory per le migrazioni di database con Servizio Migrazione del database. Inizialmente, il runtime di integrazione self-hosted deve essere creato usando l'estensione di migrazione Azure SQL in Azure Data Studio e può essere riutilizzato per altre migrazioni di database.
- Le VM con SQL Server 2008 e versioni successive come versioni di destinazione non sono supportate durante la migrazione a SQL Server in Macchine virtuali di Azure.
- Se si usa una macchina virtuale con SQL Server 2012 o SQL Server 2014, è necessario archiviare i file di backup del database di origine in un contenitore BLOB del servizio di archiviazione di Azure, anziché usare l'opzione condivisione di rete. Archiviare i file di backup come BLOB di pagine, poiché i BLOB in blocchi sono supportati solo in SQL 2016 e versioni successive.
- È necessario assicurarsi che l'estensione SQL IaaS Agent nella macchina virtuale di Azure di destinazione sia in modalità completa anziché in modalità Lightweight.
- L'estensione SQL IaaS Agent supporta solo la gestione dell'istanza del server predefinita o di un'istanza denominata singola.
- È possibile eseguire la migrazione di un massimo di 100 database alla stessa macchina virtuale di SQL Server di Azure della destinazione usando una o più migrazioni contemporaneamente. Inoltre, al termine di una o più migrazioni con 100 database, attendere almeno 30 minuti prima di avviare una nuova migrazione alla stessa macchina virtuale di SQL Server di Azure come destinazione. Inoltre, ogni operazione di migrazione (avvio della migrazione, cutover) per ogni database richiederà alcuni minuti in sequenza. Ad esempio, per eseguire la migrazione di 100 database, potrebbero essere necessari circa 200 (2 x 100) minuti per creare la coda di migrazione e circa 100 (1 x 100) minuti per tagliare tutti i 100 database (esclusi i tempi di backup e ripristino). Pertanto, la migrazione diventerà più lenta man mano che aumenta il numero di database. Microsoft consiglia di pianificare in anticipo una finestra di migrazione più lunga in base a test rigorosi di migrazione o partizionamento di un numero elevato di database in batch durante la migrazione a una VM di Azure di SQL Server.
- Oltre a configurare networking/firewall dell'account di archiviazione di Azure per consentire alla VM di accedere ai file di backup. È anche necessario configurare il networking/il firewall di SQL Server nella VM di Azure per consentire la connessione in uscita all'account di archiviazione.
- È necessario mantenere l’SQL Server di destinazione su ON sulla VM di Azure mentre è in corso la migrazione SQL. Inoltre, quando si crea una nuova migrazione, deve essere eseguito esegue il failover o annullare la migrazione.
- Errore:
Login failed for user 'NT Service\SQLIaaSExtensionQuery
. Motivo: l'istanza di SQL Server è in modalità utente singolo. Un possibile motivo è che l’SQL Server di destinazione nella VM di Azure sia in modalità di aggiornamento. Soluzione: attendere che SQL Server di destinazione nella VM di Azure esci dalla modalità di aggiornamento e avvii di nuovo la migrazione. - Errore:
Ext_RestoreSettingsError, message: Failed to create restore job.;Cannot create file 'F:\data\XXX.mdf' because it already exists
. Soluzione: connettersi a SQL Server di destinazione nella VM di Azure ed eliminare il file XXX.mdf. Quindi, avviare nuovamente la migrazione.
Limitazioni di Azure Data Studio
Impossibile avviare il servizio di migrazione SQL: Errore: Errore della richiesta
Messaggio:
Error at ClientRequest.<anonymous> (c:\Users\MyUser\.azuredatastudio\extensions\microsoft.sql-migration-1.4.2\dist\main.js:2:7448) at ClientRequest.emit (node:events:538:35) at TLSSocket.socketOnEnd (node:_http_client:466:9) at TLSSocket.emit (node:events:538:35) at endReadableNT (node:internal/streams/readable:1345:12) at process.processTicksAndRejections (node:internal/process/task_queues:83:21)
Causa: questo problema si verifica quando Azure Data Studio non è in grado di scaricare il pacchetto MigrationService da https://github.com/microsoft/sqltoolsservice/releases. L'errore di download può essere dovuto al lavoro di rete disconnesso o alle impostazioni proxy non risolte.
Raccomandazione: il modo sicuro per risolvere questo problema consiste nel scaricare manualmente il pacchetto. Seguire i passaggi di mitigazione descritti in questo link: https://github.com/microsoft/azuredatastudio/issues/22558#issuecomment-1496307891