Spostamento dei database di sistema
In questo argomento viene descritta la procedura per lo spostamento dei database di sistema in SQL Server. Lo spostamento dei database di sistema può risultare utile nelle situazioni seguenti:
Recupero da errore. Ad esempio, il database è in modalità sospetta oppure viene chiuso a causa di un errore hardware.
Rilocazione pianificata.
Rilocazione per attività pianificate di manutenzione dei dischi.
In questo argomento
Prima di iniziare
Procedura di rilocazione pianificata e manutenzione pianificata del disco
Procedura di recupero da errore
Procedura di spostamento del database master
Completamento: operazioni da effettuare dopo lo spostamento di tutti i database di sistema
Esempio di spostamento del database tempdb
Prima di iniziare
Prima di implementare le procedure definite in questo argomento, esaminare le informazioni riportate di seguito.
Le procedure seguenti consentono di spostare i file di database all'interno della stessa istanza di SQL Server. Per spostare un database in un'altra istanza di SQL Server o in un altro server, utilizzare le operazioni di backup e ripristino o di collegamento e scollegamento.
Il database delle risorse non può essere spostato.
Le procedure descritte in questo argomento richiedono il nome logico dei file di database. Per ottenere il nome, eseguire una query sulla colonna name della vista del catalogo sys.master_files.
Importante |
---|
Se si sposta un database di sistema e successivamente si ricompila il database master, è necessario spostare nuovamente il database di sistema, in quanto con l'operazione di ricompilazione tutti i database di sistema vengono installati nei rispettivi percorsi predefiniti. Per ulteriori informazioni sulla ricompilazione del database master, vedere la sezione relativa alla ricompilazione dei database di sistema e del Registro di sistema in Procedura: Installazione di SQL Server 2008 R2 dal prompt dei comandi. |
[Torna all'inizio]
Procedura di rilocazione pianificata e manutenzione pianificata del disco
Per spostare un file di dati o di log del database di sistema nell'ambito di un'operazione di rilocazione pianificata o di manutenzione pianificata, attenersi alla procedura seguente. Questa procedura è valida per tutti i database di sistema ad eccezione dei database master e Resource.
Per ogni file che si desidera spostare, eseguire l'istruzione seguente.
ALTER DATABASE database_name MODIFY FILE ( NAME = logical_name , FILENAME = 'new_path\os_file_name' );
Arrestare l'istanza di SQL Server o arrestare il sistema per eseguire la manutenzione. Per ulteriori informazioni, vedere Interruzione di servizi.
Spostare il file o i file nella nuova posizione.
Riavviare l'istanza di SQL Server o il server. Per ulteriori informazioni, vedere Avvio e riavvio di servizi.
Verificare la modifica del file eseguendo la query seguente.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID(N'<database_name>');
Se il database msdb viene spostato e l'istanza di SQL Server è configurata per Posta elettronica database, completare i passaggi aggiuntivi riportati di seguito.
Verificare che Service Broker sia abilitato per il database msdb eseguendo la query riportata di seguito.
SELECT is_broker_enabled FROM sys.databases WHERE name = N'msdb';
Per ulteriori informazioni sull'abilitazione di Service Broker, vedere ALTER DATABASE (Transact-SQL).
Verificare il funzionamento di Posta elettronica database inviando un messaggio di prova. Per ulteriori informazioni, vedere Risoluzione dei problemi relativi a Posta elettronica database.
[Torna all'inizio]
Procedura di recupero da errore
Se è necessario spostare un file a causa di un errore hardware, eseguire la procedura seguente per rilocare il file in una nuova posizione. Questa procedura è valida per tutti i database di sistema ad eccezione dei database master e Resource.
Importante |
---|
Se non è possibile avviare il database, ovvero se il database è in modalità sospetta o in stato non recuperato, il file può essere spostato solo dai membri del ruolo predefinito sysadmin. |
Arrestare l'istanza di SQL Server, se avviata.
Avviare l'istanza di SQL Server in modalità di recupero del solo database master digitando uno dei comandi seguenti al prompt dei comandi. I parametri specificati in questi comandi fanno distinzione tra maiuscole e minuscole. I comandi hanno esito negativo se i parametri non vengono specificati come illustrato.
Per l'istanza predefinita (MSSQLSERVER), eseguire il comando seguente:
NET START MSSQLSERVER /f /T3608
Per un'istanza denominata, eseguire il comando seguente:
NET START MSSQL$instancename /f /T3608
Per ulteriori informazioni, vedere Procedura: Avvio di un'istanza di SQL Server (comandi net).
Per ogni file che si desidera spostare, utilizzare i comandi sqlcmd oppure SQL Server Management Studio per eseguire l'istruzione seguente.
ALTER DATABASE database_name MODIFY FILE( NAME = logical_name , FILENAME = 'new_path\os_file_name' )
Per ulteriori informazioni sull'utilizzo dell'utilità sqlcmd, vedere Utilizzo dell'utilità sqlcmd.
Chiudere l'utilità sqlcmd o SQL Server Management Studio.
Arrestare l'istanza di SQL Server. Ad esempio, eseguire NET STOP MSSQLSERVER.
Spostare il file o i file nella nuova posizione.
Riavviare l'istanza di SQL Server. Ad esempio, eseguire NET START MSSQLSERVER.
Verificare la modifica del file eseguendo la query seguente.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID(N'<database_name>');
[Torna all'inizio]
Procedura di spostamento del database master
Per spostare il database master, effettuare i passaggi riportati di seguito.
Fare clic sul pulsante Start, scegliere Tutti i programmi, Microsoft SQL Server, Strumenti di configurazione e quindi fare clic su Gestione configurazione SQL Server.
Nel nodo Servizi di SQL Server fare clic con il pulsante destro del mouse sull'istanza di SQL Server, ad esempio SQL Server (MSSQLSERVER), e scegliere Proprietà.
Nella finestra di dialogo delle proprietà di SQL Server (instance_name) fare clic sulla scheda Avanzate.
Modificare i valori Parametri di avvio in modo da puntare al percorso pianificato per i file di dati e di log del database master, quindi scegliere OK. Lo spostamento del file del registro errori è facoltativo.
Il valore del parametro per il file di dati deve seguire il parametro -d e il valore per il file di log deve seguire il parametro -l. Nell'esempio seguente vengono mostrati i valori di parametro per il percorso predefinito dei file di dati e di log del database master.
-dC:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL\DATA\master.mdf -lC:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL\ DATA\mastlog.ldf
Se la rilocazione pianificata dei file di dati e di log del database master è E:\SQLData, i valori dei parametri verranno modificati nel modo seguente:
-dE:\SQLData\master.mdf -lE:\SQLData\mastlog.ldf
Arrestare l'istanza di SQL Server facendo clic con il pulsante destro del mouse sul nome dell'istanza e scegliendo Arresta.
Spostare i file master.mdf e mastlog.ldf nel nuovo percorso.
Riavviare l'istanza di SQL Server.
Verificare la modifica dei file per il database master eseguendo la query riportata di seguito.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID('master'); GO
[Torna all'inizio]
Completamento: operazioni da effettuare dopo lo spostamento di tutti i database di sistema
Se tutti i database di sistema sono stati spostati in un nuovo volume o unità oppure in un altro server con una lettera di unità diversa, effettuare gli aggiornamenti riportati di seguito.
Modificare il percorso del log di SQL Server Agent Se non si aggiorna questo percorso, non sarà possibile avviare SQL Server Agent.
Modificare il percorso predefinito del database. La creazione di un nuovo database potrebbe non venir completata correttamente se la lettera di unità e il percorso specificati come posizione predefinita non esistono.
Modificare il percorso del log di SQL Server Agent
In Esplora oggetti di SQL Server Management Studio espandere SQL Server Agent.
Fare clic con il pulsante destro del mouse su Registri errori, quindi scegliere Configura.
Nella finestra di dialogo Configura registri errori di SQL Server Agent specificare il nuovo percorso del file SQLAGENT.OUT. Il percorso predefinito è C:\Programmi\Microsoft SQL Server\MSSQL10_50.<nome_istanza>\MSSQL\Log\.
Modificare il percorso predefinito del database
In Esplora oggetti di SQL Server Management Studio fare clic con il pulsante destro del mouse sul server SQL Server, quindi scegliere Proprietà.
Nella finestra di dialogo Proprietà server selezionare Impostazioni database.
In Percorsi predefiniti database selezionare il nuovo percorso sia per i file di dati sia per quelli di log.
Per completare la modifica, avviare e arrestare il servizio SQL Server.
[Torna all'inizio]
Esempi
A. Spostamento del database tempdb
Nell'esempio seguente i file dei dati e di log del database tempdb vengono spostati in una nuova posizione nell'ambito di una rilocazione pianificata.
Nota
Poiché tempdb viene ricreato a ogni avvio del servizio SQL Server, non è necessario spostare fisicamente i file di dati e di log. I file vengono creati nella nuova posizione quando il servizio viene riavviato nel passaggio 3. Fino al riavvio del servizio, nel database tempdb continueranno a essere utilizzati i file di dati e di log disponibili nella posizione esistente. Una volta riavviato il servizio SQL Server, è possibile eliminare i file di dati e di log del database tempdb dal percorso originale.
Determinare i nomi dei file logici del database tempdb e la relativa posizione corrente sul disco.
SELECT name, physical_name AS CurrentLocation FROM sys.master_files WHERE database_id = DB_ID(N'tempdb'); GO
Modificare il percorso di ogni file tramite ALTER DATABASE.
USE master; GO ALTER DATABASE tempdb MODIFY FILE (NAME = tempdev, FILENAME = 'E:\SQLData\tempdb.mdf'); GO ALTER DATABASE tempdb MODIFY FILE (NAME = templog, FILENAME = 'F:\SQLLog\templog.ldf'); GO
Arrestare e riavviare l'istanza di SQL Server.
Verificare la modifica dei file.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID(N'tempdb');
Eliminare i file tempdb.mdf e templog.ldf dalla posizione originale.
[Torna all'inizio]
Vedere anche