Skip to main content

Ciao Community,

ho preparato un articolo per riportare la mia esperienza nel backup di database Oracle con agent FS e RMAN plug-in. Spero possa essere utile.

Un grazie ai colleghi @marco_s @ggrippo 

La conservazione dei dati di backup di un database di tipo Oracle è sempre complessa. Il mondo dei DBA Oracle è fortemente inclinato a restare chiuso nel guscio della confort zone e riuscire a penetrarlo non è mai troppo semplice.

Intanto si chiedono perché, se qualsiasi tool di backup utilizza i comandi RMAN, si debbano affidare ad altre persone quando possono fare tutto loro.

Oggi vado a presentare uno scenario reale di installazioni su VM Oracle Linux.

Ma comincio col mostrare lo schema di come funziona il backup di Oracle con il plugin

SCENARIO:

Tutte le macchine su cui è presente Oracle sono VM Linux su OLVM per cui era necessario provvedere all'installazione degli agent di tipo File System e dei Plug-in per Oracle RMAN.

I database erano sia di tipo RAC che singoli database.

A tutte le vm è stata aggiunta una scheda di rete su una VLAN dedicata al backup che si connette direttamente al VBR server.

Il Plug-in può funzionare in due modalità: modalità standalone e modalità gestita.

Nel mio caso ho utilizzato la modalità gestita con la quale è possibile automatizzare l'installazione e l'upgrade del plug-in su più server attraverso i Protection group.

La cosa fondamentale da tenere presente sono i prerequisiti che si rendono necessari al corretto funzionamento di tutte le fasi ossia:

  1. Installazione e configurazione
  2. Backup
  3. Restore

Installazione e configurazione

Tutte le configurazioni sono prese dalla documentazione ufficiale https://helpcenter.veeam.com/docs/backup/plugins/planning_and_preparation_oracle.html?ver=120

Innanzi tutto considerato che Veeam esegue delle query sul DB Oracle per la raccolta di informazioni statistiche su RMAN, Oracle può decidere di utilizzare spazio in alcune tabelle temporanee.

Quindi il primo passaggio da effettuare sul DB Oracle è quello di configurare la Temp Tablespace per evitare la carenza di spazio su di esse.

È possibile verificare la dimensione dello spazio delle tabelle temporanee con la seguente query SQL seguente:

SELECT * FROM DBA_TEMP_FREE_SPACE;


Oppure creare una nuova Temp Tablespace con il comando:

CREATE TEMPORARY TABLESPACE TEMP_NEW TEMPFILE '/DATA/database/ifsprod/temp_01.dbf' SIZE 500m autoextend on next 10m maxsize unlimited;
ALTER DATABASE DEFAULT TEMPORARY TABLESPACE TEMP_NEW;

 

Per configurare Veeam Plug-in su un computer Linux o Unix, è necessario utilizzare una utenza locale che faccia parte del gruppo OSDBA (tipicamente chiamato "dba") e che abbia i privilegi di SYSDBA.

Ma non basta.

Infatti sono FONDAMENTALI anche questi permessi a livello di sistema operativo:

La directory /opt/veeam deve essere scrivibile.

L'opzione di mount NOEXEC deve essere disabilitata per le directory /var e /tmp.

Per installare il plug-in, utilizzare il comando sudo o un utente con privilegi di root.

Quelli sopra indicati sono i permessi per la sola installazione del plugin.

E' necessario poi aggiungere anche altri permessi per la gestione che si trovano qui: https://helpcenter.veeam.com/docs/backup/plugins/plan_and_manage_permissions.html?ver=120#computer-with-veeam-plug-in-for-oracle-rman

In particolare

Permessi per la folder $ORACLE_HOME devono essere settati con comando chmod a 775.

The OS user account has the primary membership in the Oracle Inventory Group (oinstall) group.

NOTA: Ho appurato che anche se oinstall non è il gruppo primario "spesso" funziona tutto.

A questo punto siamo pronti all'installazione del plugin.

Ho scelta la strada più semplice per l'installazione ovvero ho creato un Protection Group al cui interno inserivo di volta in volta i server su cui era necessario eseguire l'operazione e nelle specifiche del PG ho impostato che venisse effettuata l'installazione dell'Agent Linux FS e del plug-in RMAN

Ho volontariamente lasciato senza la spunta l'auto-update e l'eventuale reboot visto che si tratta di macchine in produzione.

Il risultato, se tutti i prerequisiti sono rispettati è il seguente:

Subito dopo l'installazione parte il processo di rescan delle macchine presenti nel PG e in questa fase viene verificata la presenza di una istanza Oracle.

Lo scanning delle istanze da parte di Veeam avviene in due modi:

  1. Se è presente un file oratab, viene scansionato il contenuto. Per essere identificati correttamente, i database devono essere elencati come ORACLE_SID:ORACLE_HOME.

Se il database è elencato come DB_UNIQUE_NAME:ORACLE_HOME o il file oratab è vuoto il consiglio è quello di aggiungere la entry. Questo velocizza le operazioni.

  1. Se il file oratab non presenta alcuna riga di configurazione, viene usato il comando srvctl di Oracle e catturato il suo output.

Troubleshooting: Nel caso in cui i permessi 775 sulla $ORACLE_HOME non fossero presenti si otterrebbe una mancata visualizzazione delle istanze presenti sui server.

 

ATTENZIONE: Una annotazione specifica riguarda le installazioni di Oracle RAC.

E' necessario installare il Plugin for RMAN su tutti i nodi Oracle RAC per poter garantire i backup da ogni singolo nodo.

Completata la fase di installazione si rende necessario impostare i permessi di accesso verso il repository da parte degli agent:

Di default l'impostazione sul repository di backup è impostata su Deny to everyone

 

Nella finestra Access Permission, è importante specificare a chi si desidera concedere le giuste autorizzazioni al repository di backup ed è possibile scegliere tra:

Allow to everyone - selezionare questa opzione se si desidera concedere l'accesso al repository a qualsiasi utente. Onestamente, per motivi di sicurezza, questa opzione non è consigliata per gli ambienti di produzione.

Allow to the following accounts or groups only - selezionare questa opzione se si desidera che solo utenti specifici possano archiviare i backup in questo repository.

Quindi ho aggiunto le utenze utilizzate per il backup.

Configurazioni di rete

La rete, anche per il plug-in RMAN, è fondamentale per garantire delle prestazioni ottimali del backup.

Veeam consiglia, ove possibile, di configurare le seguenti impostazioni di rete:

 

Item

Value

Comments

Jumbo Frames

Enable

Veeam Repository and Oracle Servers

Network Speed

Mutiple 10 Gbps cards

ideally dedicated layer 2 network for backup operation

IPV6

Disable

IPv6 should be disabled on Oracle Database server when possible

 

General Troubleshooting

Sul server dove è installato il plugin si possono verificare i logs nelle seguenti cartelle:

 /tmp/veeam_plugin_logs/

 /var/log/VeeamBackup/

 /tmp/OracleProxyLogs/

Le configurazioni del plugin sono verificabili nel file /opt/veeam/VeeamPluginforOracleRMAN/veeam_config.xml

BACKUP

Il job di backup è stato creato direttamente dall'interfaccia del VBR Server.

E' stato creato un job di backup per ogni database aggiungendo sempre l'instanza che veniva trovata

Attenzione: è necessario specificare il numero di canali RMAN anche nelle impostazioni avanzate nella tab Oracle (vedi immagine)

 

E inoltre la configurazione più importante per la parte degli archive logs.

 

RESTORE

Anche per la restore ci siamo affidati all'interfaccia di Veeam grazie all'Explorer per Oracle.

Trattandosi di backup effettuato con Agent non è possibile effettuare la pubblicazione istantanea o la restore istantanea ma ci sono solo queste opzioni

Dopo aver scelto la tipologia di restore da effettuare e inserito il target server su cui effettuare la restore la procedura chiede di specificare alcuni settaggi per l'istanza.

Poiché i test effettuati prevedevano la restore su altro server è stato necessario scegliere la seconda opzione indicando un nome differente per l'istanza

Altro passaggio importante è legato al momento in cui si vuole effettuare la restore.

Ho testato le prime due possibilità, ovvero la restore all'ultimo backup disponibile e la restore da una apposita sequenza.

In entrambi i casi è stato verificato che la restore si è completata con successo mantenendo gli archive logs come da richiesta (tutti nel primo caso, fino alla swquenza indicata nel secondo).

Quindi è partito il check per verificare se i path sul server esistono oppure dvono essere creati, e l'ultimo passaggio è indicare il numero dei channel da utilizzare per la restore.

ATTENZIONE: Prima di avviare la restore su un altro server è necessario specificare le credenziali di un account utente con cui è stato creato il backup.

 

Eseguire il seguente comando:

OracleRMANConfigTool --set-auth-data-for-restore

 

Verrà chiesto di selezionare un metodo di autenticazione per accedere al backup.

Quindi per accedere ai file di backup utilizzando le apposite credenziali digitare 1:

Select authentication type or disable the functionality:

0. To disable the functionality

1. Credentials

2. Recovery token

Enter authentication type number:

1

  1. Quindi verrà chiesto di inserire le credenziali:

Enter username:

Enter password for <username>:

 

Ref: https://helpcenter.veeam.com/docs/backup/plugins/restore_other_server_rman.html?ver=120#specifying-credentials

 

Da i test di verifica è emerso che tutto è completato con successo

STATO DB:

 

SQL> SELECT INSTANCE_NAME, STATUS, DATABASE_STATUS FROM V$INSTANCE;

 

INSTANCE_NAME    STATUS       DATABASE_STATUS

---------------- ------------ -----------------

database     OPEN         ACTIVE

 

ARCHIVE LOG GENERATI:

 

SQL> select trunc(COMPLETION_TIME) TIME, SUM(BLOCKS * BLOCK_SIZE)/1024/1024 SIZE_MB from V$ARCHIVED_LOG group by trunc (COMPLETION_TIME) order by 1;

 

TIME         SIZE_MB

--------- ----------

15-MAY-24 172.806641

16-MAY-24 2035.29736

 

SIZE DATABASE:

 

SQL> select sum(bytes)/1024/1024/1024 GB from (

select bytes from dba_data_files

union all

select bytes from DBA_TEMP_FILES

union all

select bytes file_name from v$log

union all

SELECT (block_size * file_size_blks) bytes FROM v$controlfile

);  2    3    4    5    6    7    8    9

 

        GB

----------

134.13028

ottima guida grazie a tutti,


Grazie @Andanet per aver condiviso la tua esperienza, tornerà sicuramente utile a qualcuno!


molte grazie, davvero


ho un cliente che necessita di avere una retention di tipo GFS. immagino non sia possibile farlo daalla console di Veeam ma solo gestendo il plugin “stand alone” e seguendo questo approccio

(inoltre mi da uno stranissimo errore l’explorer per il restore, aprirò un caso… ma è un’altra storia)


Io ho tamponato con i copy job. Non è la stessa cosa ma il risultato è lo stesso. 

 

Ah... Un voto per il blog del mese lo merito? 😁😁😁


Comment