Backup e ripristino: database di sistema (SQL Server)

Si applica a: sìSQL Server (tutte le versioni supportate)

SQL Server gestisce un set di database a livello di sistema, denominati database di sistema, fondamentali per un corretto funzionamento di un'istanza del server. Dopo ogni aggiornamento importante, è necessario eseguire il backup di numerosi database di sistema. Alcuni database di sistema di cui è necessario eseguire sempre il backup sono msdb, master e model. Se un database usa la replica nell'istanza del server, è necessario eseguire il backup anche di un database di sistema distribution . I backup di questi database di sistema consentono di ripristinare e recuperare il sistema SQL Server qualora si verifichi un errore a livello di sistema, ad esempio un problema che impedisce di utilizzare un disco rigido.

Nella tabella seguente è presentato un riepilogo di tutti i database di sistema.

Database di sistema Descrizione Necessità di backup modello di recupero Commenti
master Nel database vengono registrate tutte le informazioni a livello di sistema relative a un sistema SQL Server . Semplice Eseguire il backup di master con la frequenza necessaria a garantire una sufficiente protezione dei dati in base alle esigenze aziendali. È consigliabile pianificare i backup con regolarità, pianificazione che è possibile integrare con backup aggiuntivi dopo un aggiornamento importante.
model Modello per tutti i database creati nell'istanza di SQL Server. Configurabile dall'utente* Eseguire il backup di model solo se necessario in base alle esigenze aziendali, ad esempio immediatamente dopo la personalizzazione delle opzioni del database.

Procedura consigliata: creare solo backup completi del database model in base alle esigenze. Poiché nel database model vengono apportate solo di rado lievi modifiche, il backup del log non è necessario.
msdb Il database utilizzato da SQL Server Agent per la pianificazione di avvisi e processi e per la registrazione di operatori. msdb contiene anche tabelle di cronologia, ad esempio tabelle di cronologia di backup e ripristino. Con registrazione minima (impostazione predefinita) Eseguire il backup di msdb a ogni aggiornamento.
Resource (RDB) Database di sola lettura che include copie di tutti gli oggetti di sistema forniti con SQL Server No - Il database Resource risiede nel file mssqlsystemresource.mdf, che contiene solo codice. SQL Server non può quindi eseguire il backup del database Resource .

Nota: è possibile eseguire un backup basato su file o su disco sul file mssqlsystemresource.mdf, considerando il file come un file binario con estensione exe anziché come un file di database. Non è tuttavia possibile utilizzare la funzionalità di ripristino di SQL Server su questi backup. Il ripristino di una copia di backup di mssqlsystemresource.mdf può essere eseguito solo manualmente, prestando attenzione a non sovrascrivere il database Resource corrente con una versione non aggiornata e potenzialmente non sicura.
tempdb Area di lavoro per il mantenimento dei set di risultati temporanei o intermedi. Questo database viene ricreato ogni volta che viene avviata un'istanza di SQL Server . Quando l'istanza del server viene chiusa, i dati inclusi in tempdb vengono eliminati in modo definitivo. No Semplice Non è possibile eseguire il backup del database di sistema tempdb .
Configurare la distribuzione Database esistente solo se il server è configurato come server di distribuzione repliche. In questo database sono memorizzati metadati e dati della cronologia per tutti i tipi di replica, nonché transazioni per la replica transazionale. Semplice Per informazioni su quando eseguire il backup del database distribution , vedere Eseguire il backup e ripristino di database replicati.

*Per conoscere l'attuale modello di recupero del modello, vedere Visualizzare o modificare il modello di recupero di un database (SQL Server) o sys.databases (Transact-SQL).

Limitazioni sul ripristino di database di sistema

  • I database di sistema possono essere ripristinati solo da backup creati nella versione di SQL Server eseguita nell'istanza del server. Per ripristinare un database di sistema in un'istanza del server eseguita in SQL Server 2012 (11.x) SP1, ad esempio, sarà necessario utilizzare un backup del database creato dopo l'aggiornamento dell'istanza del server a SQL Server 2012 (11.x) SP1.

  • Per ripristinare un database, è necessario che l'istanza di SQL Server sia in esecuzione. Per l'avvio di un'istanza di SQL Server è necessario che il database master sia accessibile e utilizzabile almeno in parte. Se il database master diventa inutilizzabile, è possibile ripristinare uno stato utilizzabile del database in uno dei modi seguenti:

    • Ripristinare il database master da un backup del database corrente.

      Se è possibile avviare l'istanza del server, dovrebbe essere possibile anche ripristinare il database master da un backup completo del database.

    • Ricompilare il database master da zero.

      Se non è possibile avviare in seguito a gravi danni al database master SQL Server, è necessario ricompilare il database master. Per altre informazioni, vedere Ricompilare database di sistema.

      Importante

      La ricompilazione del database master comporta la ricompilazione di tutti i database di sistema.

  • In alcune circostanze, per i problemi relativi al recupero del database modello può essere necessario ricompilare i database di sistema o sostituire i file mdf e ldf del database modello. Per altre informazioni, vedere Ricompilare database di sistema.

Vedere anche

Database di distribuzione
Database master
Database msdb
Database model
Database Resource
Database tempdb