Novo no DB. Interessado em Oracle Data Guard. Novo trabalhando com RMAN.
Tudo isso é apenas para teste e não envolve nenhum tipo de env de produção.
Fazendo uso da documentação ORACLE:
- Guia passo a passo sobre como criar espera física usando RMAN DUPLICATE...FROM ACTIVE DATABASE (Doc ID 1075908.1)
. .================================================= =========================. .
O banco de dados primário:
[oracle@ol12c pridb]$ env | grep ORA
ORACLE_UNQNAME=cdb1
ORACLE_SID=pridb
ORACLE_BASE=/u01/app/oracle
ORACLE_HOSTNAME=ol12c.localdomain
ORACLE_HOME=/u01/app/oracle/product/12.1.0.2/db_1
SQL> startup pfile=/u01/app/oracle/product/12.1.0.2/db_1/dbs/initpridb.ora;
SQL> show parameter db_recovery_file_dest
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest string /u01/app/oracle/fast_recovery_
area
db_recovery_file_dest_size big integer 2G
SQL> archive log list
Database log mode Archive Mode
Automatic archival Enabled
Archive destination USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence 12
Next log sequence to archive 13
Current log sequence 13
. .================================================= =========================. .
2. A Espera:
[oracle@ol12c stbdb]$ env | grep ORA
ORACLE_UNQNAME=cdb1
ORACLE_SID=stbdb
ORACLE_BASE=/u01/app/oracle
ORACLE_HOSTNAME=ol12c.localdomain
ORACLE_HOME=/u01/app/oracle/product/12.1.0.2/db_1
SQL> startup nomount pfile='/u01/app/oracle/product/12.1.0.2/db_1/dbs/initstbdb.ora'
SQL> show parameter db_recovery_file_dest
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest string /u01/app/oracle/fast_recovery_
area/stbdb
db_recovery_file_dest_size big integer 2G
. .================================================= =========================. .
3. RMAN (no banco de dados primário):
[oracle@ol12c pridb]$ rman
RMAN> connect target sys/oracle@pridb
connected to target database: PRIDB (DBID=1212094364)
RMAN> connect auxiliary sys/oracle@stbdb
connected to auxiliary database: PRIDB (not mounted)
. .================================================= =========================. .
4. Erro:
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-00558: error encountered while parsing input commands
RMAN-01009: syntax error: found "db_unique_name": expecting one of: "archivelog, autobackup, auxiliary, auxname, backup, catalog, command, compression, controlfile, database, dbid, decryption, default, echo, encryption, high, incarnation, incremental, long, maxcorrupt, maxseq, newname, nocfau, numwidth, restore, snapshot, to restore point, until restore point, until, "
RMAN-01007: at line 1 column 1 file: standard input
E
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-00558: error encountered while parsing input commands
RMAN-01009: syntax error: found "identifier": expecting one of: "archivelog, autobackup, auxiliary, auxname, backup, catalog, command, compression, controlfile, database, dbid, decryption, default, echo, encryption, high, incarnation, incremental, long, maxcorrupt, maxseq, newname, nocfau, numwidth, restore, snapshot, to restore point, until restore point, until, "
RMAN-01008: the bad identifier was: log_archive_dest_2
RMAN-01007: at line 1 column 7 file: standard input
Recebo o erro RMAN-01008 para todos os parâmetros especificados no comando a partir de log_file_name_convert.
. .================================================= =========================. .
5. Minha entrada:
run
{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
allocate channel c4 type disk;
allocate auxiliary channel aux type disk;
duplicate target database for standby from active database
parameter_value_convert'pridb','stbdb'
set db_unique_name='stbdb'
set db_file_name_convert='pridb','stbdb'
set log_file_name_convert='pridb','stbdb'
set control_files='/u01/app/oracle/oradata/stbdb/stbdb_control1.ctl'
set standby_file_management='AUTO'
set log_archive_max_processes='10'
set fal_client='stbdb'
set fal_server='pridb'
set standby_file_management='AUTO'
set log_archive_config='dg_config=(pridb,stbdb)'
set log_archive_dest_1='location=USE_DB_RECOVERY_FILE_DEST valid_for=(all_logfiles,all_roles) db_unique_name=stbdb'
set log_archive_dest_2='service=testdb ASYNC valid_for=(ONLINE_LOGFILE,PRIMARY_ROLE) db_unique_name=stbdb'
;
}
Primeiro eu peguei:
RMAN-05557 : A instância de destino não foi iniciada com o arquivo de parâmetro do servidor
Porque eu estava tentando: duplicate target database for standby from active database spfile
e não estou iniciando de um spfile, mas diretamente do pfile.
De acordo com minha pesquisa, devo ser capaz de não especificar o SPfile:
Assim mudei de duplicate target database for standby from active database spfile
para duplicate target database for standby from active database
qual deveria funcionar conforme mencionado nos links que verifiquei.
--> Mas quais parâmetros estou atualizando agora? Para mim, isso não parece lógico. .
O código acima foi executado uma vez com sucesso na alocação dos canais, mas depois parou e começou a gerar erros.
Atualmente estou executando o script rman checksyntax
apenas para ter certeza de não quebrar nada .. :)
. .================================================= =========================. .
Você pode por favor me ajudar com:
Eu tentando entender melhor o RMAN.
Descobrir o que estou fazendo de errado na situação acima. (+ Por quê!)
Eu tenho mais interesse em entender o que está acontecendo etc do que fazer isso funcionar rapidamente.
(Mesmo que funcionasse seria ótimo, claro! :) O objetivo neste momento é aprender)
Agradeço antecipadamente por sua ajuda!
. .================================================= =========================. .
SOLUÇÃO
UM SPFILE É NECESSÁRIO
No banco de dados primário:
SQL> create spfile from pfile='/u01/app/oracle/product/12.1.0.2/db_1/dbs/initpridb.ora';
File created.
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup;
ORACLE instance started.
Total System Global Area 1073741824 bytes
Fixed Size 2932632 bytes
Variable Size 671088744 bytes
Database Buffers 394264576 bytes
Redo Buffers 5455872 bytes
Database mounted.
Database opened.
Então iniciei o RMAN e executei o script está rodando enquanto falamos! :) - SIM!
seguinte erro:
RMAN-05537: DUPLICATE sem conexão TARGET quando a instância auxiliar é iniciada com spfile não pode usar a cláusula SPFILE
Resolvido atualizando os valores do script e reconectando o dbs.
Roteiro final usado:
RMAN> run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
allocate channel c4 type disk;
allocate auxiliary channel aux type disk;
duplicate target database for standby from active database
spfile
parameter_value_convert'pridb','stbdb'
set db_unique_name='stbdb'
set db_file_name_convert='/u01/app/oracle/oradata/pridb/PRIDB/datafile/','/u01/app/oracle/oradata/stbdb/STBDB/datafile/'
set log_file_name_convert='/u01/app/oracle/oradata/pridb/PRIDB/onlinelog/','/u01/app/oracle/oradata/stbdb/STBDB/onlinelog/'
set control_files='/u01/app/oracle/oradata/stbdb/stbdb_control1.ctl'
set standby_file_management='AUTO'
set log_archive_max_processes='10'
set fal_client='stbdb'
set fal_server='pridb'
set standby_file_management='AUTO'
set log_archive_config='dg_config=(pridb,stbdb)'
set log_archive_dest_1='location=USE_DB_RECOVERY_FILE_DEST valid_for=(all_logfiles,all_roles) db_unique_name=stbdb'
set log_archive_dest_2='service=testdb ASYNC valid_for=(ONLINE_LOGFILE,PRIMARY_ROLE) db_unique_name=stbdb'
;
}
parameter_value_convert
não pode ser usado semspfile
.DUPLICAR :
dupOptionList::=
O banco de dados primário foi iniciado com spfile:
O modo de espera é iniciado com pfile:
Duplicado:
Seu primário deve usar um spfile.