Sommario:
Video: Tutorial italiano puntata 1 di Blackmagic DaVinci Resolve 2024
Potresti sostenere che lo spostamento del database avanti e indietro con Oracle 12c Recovery Manager con buoni backup è possibile. Tuttavia, il ripristino di un database di grandi dimensioni in un punto precedente richiede molto tempo e è noioso. Inoltre, se non torni indietro abbastanza, devi ricominciare dall'inizio.
È possibile che si desideri eseguire il flashback del database per questi motivi:
-
Scenari di test ripetuti: Si supponga di avere un'applicazione che si sta testando nel proprio ambiente di sviluppo. Ogni volta che esegui l'applicazione, cambia i tuoi dati. Si desidera ripristinare i dati ai valori originali prima del test successivo. Flashback è uno strumento eccellente per questo.
-
Corruzione dei dati logici: Forse qualcuno ha eseguito accidentalmente il programma sbagliato nel proprio ambiente di produzione; è necessario tornare a un punto prima che si verifichi l'errore. Si potrebbe fare questo con un recupero di dati, ma Flashback è più veloce e più facile.
-
Procedure di distribuzione: Forse stai pubblicando una nuova versione del tuo codice che aggiorna tutti i tipi di oggetti nello schema di produzione con DDL e DML. È possibile eseguire facilmente il rollback se l'applicazione non funziona correttamente nei parametri di prestazione target.
Flashback Database funziona registrando informazioni extra che consentono di eseguire il rollback delle transazioni senza eseguire un ripristino completo del database. Non solo, ma funziona molto velocemente. Il database Flashback ha queste funzioni rapide, tra le altre:
-
Puoi aprire il database in modalità di sola lettura per vedere se sei tornato abbastanza indietro.
-
Non abbastanza lontano? Riavvolgi rapidamente indietro.
-
Troppo lontano? Rotolare di nuovo in avanti.
È possibile eseguire tutte queste attività con semplici comandi in SQL * Plus o Oracle Enterprise Manager. Per farli con RMAN, stai parlando tra più ripristini completi e molto tempo.
Come configurare e abilitare il database Flashback
Il database di Flashback funziona diversamente dalle funzioni di Flashback. Con il database Flashback, Oracle archivia un file chiamato log di flashback. I registri di flashback hanno i dati per ripristinare i blocchi a una volta precedente. I log dei flashback sono archiviati in flash_recovery_area.
Qui entrano in gioco due variabili:
-
Quanto indietro vuoi andare?
-
Quanti dati sono stati modificati nel tuo database entro quel periodo di tempo?
Più indietro si va e più modifiche si hanno, più log di flashback si generano. Assicurati di avere abbastanza spazio per archiviare i registri, altrimenti non lampeggerà da nessuna parte.
Se stai pensando di implementare il Database Flashback, potrebbe essere necessario ingrandire il parametro db_recovery_file_dest_size.Quanto si ingrandisce dipende dalle due variabili: quanto indietro e quanti dati? Se si desidera un buon punto di partenza, utilizzare questa formula:
Nuova area area di recupero Flash = Dimensione area recupero flash corrente + Dimensione totale database × 0. 3
In sostanza, si sta tentando di riservare circa il 30 percento di la dimensione totale del database nell'area di recupero flash per i log di flashback.
Da quel momento in poi, è possibile monitorare lo spazio occupato dai log di flashback.
Dopo aver configurato l'area di recupero Flash, attivare la funzione Flashback nel database seguendo questi passaggi:
-
Considerare quanto indietro si desidera essere in grado di eseguire il flashback.
Il valore predefinito è 24 ore (o 1, 440 minuti). Supponiamo che tu voglia essere in grado di eseguire il flashback fino a 48 ore.
-
Configura quanto indietro vuoi andare con il parametro db_flashback_retention_target; per fare ciò, accedere a SQL come SYSDBA e digitare
In questo esempio, il tempo è impostato per 2, 880 minuti (48 ore).
Dovresti vedere quanto segue per tutto il tempo che scegli.
Sistema alterato.
-
Spegni il tuo database e riavvialo in modalità mount.
-
Inserisci il database in modalità flashback digitando questo:
Dovresti vedere questo:
Database modificato.
-
Aprire il database digitando questo:
Si dovrebbe vedere questo:
Database modificato.
Ora che il database è in modalità flashback, è possibile eseguire il flashback in qualsiasi momento all'interno della finestra di Flashback.
Come eseguire il rollback del database Oracle 12c
Quando il database deve essere ripristinato, non preoccuparti. Il processo è relativamente facile.
Lampeggia indietro un database rimuove qualsiasi modifica avvenuta dopo il momento in cui è stato scelto di tornare. Non prendere questa considerazione alla leggera.
Per vedere quanto puoi andare indietro, digita questo:
Dovresti vedere qualcosa del tipo:
OLDEST_FLASHBACK_TIM -------------------- 14 -AUG-2013 06: 34: 03
db_flashback_retention_target dovrebbe essere circa il limite di quel periodo di tempo. Potresti trovarlo più lungo se lo spazio non è un problema e il database non ha ancora cancellato i vecchi log di flashback.
Supponiamo che un utente abbia abbandonato accidentalmente lo schema delle risorse umane dal database circa un'ora fa.
-
Arresta il database.
-
Riavvia in modalità di montaggio.
-
Digitare quanto segue, dove 1 è il numero di ore che si desidera riprendere:
Si dovrebbe vedere questo:
Flashback completo.
-
Controlla il flashback prima di renderlo permanente:
Dovresti vedere questo:
Database modificato.
-
Se sei soddisfatto del risultato, vai al passaggio 6. Se non sei soddisfatto dell'ora, vai al passaggio 9.
-
Spegni il database.
-
Avvia il database in modalità di montaggio.
-
Apri il database con Resetlogs:
Dovresti vedere questo:
Database modificato.
-
Riavvia il database in modalità di montaggio.
-
Digitare quanto segue:
Si dovrebbe vedere questo:
Ripristino del supporto completo.
-
Avvia il tuo database in modalità mount.
Se si desidera eseguire il flashback di un timestamp, andare al passaggio 12. Se si desidera eseguire il flashback su un punto di ripristino creato in precedenza, andare al punto 13.
Per ulteriori informazioni sui punti di ripristino, consultare la sezione "Utilizzo" ripristinare i punti "barra laterale.
-
Digitare quanto segue:
Si dovrebbe vedere questo:
Flashback completo.
-
Digitare quanto segue se si desidera eseguire il flashback su un punto di ripristino:
Si dovrebbe vedere questo:
Flashback completo.