cdb 数据库搭建dataguard

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: cdb dataguard,cdb搭建dataguard,12c,18c

数据库版本:
12.2.0.1.0
实验环境:
192.168.0.196 prod04 主数据库(sid cdb)
192.168.0.197 prod05 备数据库(sid cdb)

主备数据库数据文件目录相同。(/u01/app/oracle/oradata/cdb/)

1, 主数据库环境准备

1,开启归档
2,启动监听
3,配置如下参数
LOG_FILE_NAME_CONVERT,db_file_name_conver,standby_file_manage,
4,添加standby log

#开启强制日志和归档
ALTER DATABASE FORCE LOGGING;
SHUTDOWN IMMEDIATE;
STARTUP MOUNT;
ALTER DATABASE ARCHIVELOG;
ALTER DATABASE OPEN;
#设置文件位置,文件管理方式
alter system set standby_file_management='AUTO';
alter system set LOG_FILE_NAME_CONVERT='/u01/app/oracle/oradata/cdb/','/u01/app/oracle/oradata/cdb/'  scope=spfile;
alter system set db_file_name_convert='/u01/app/oracle/oradata/cdb/','/u01/app/oracle/oradata/cdb/'  scope=spfile;
#stantdby redo:(大小必须和redo大小一致)
ALTER DATABASE ADD STANDBY LOGFILE '/u01/app/oracle/oradata/cdb/s0111.log' size 200m;
ALTER DATABASE ADD STANDBY LOGFILE '/u01/app/oracle/oradata/cdb/s0222.log' size 200m;
ALTER DATABASE ADD STANDBY LOGFILE '/u01/app/oracle/oradata/cdb/s0333.log' size 200m;

2,备库环境

1,备库创建密码文件
2,启动监听
3,spfile文件
4,建立目录文件

密码文件:

orapwd file=orapwsborcl password=oracle  format=12

spfile

(fal_server='CDB',log_archive_config='DG_CONFIG=(cdb,sbcdb)',db_unique_name='sbcdb')

*.audit_file_dest='/u01/app/oracle/admin/cdb/adump'
*.audit_trail='DB'
*.compatible='12.2.0'
*.connection_brokers='((TYPE=DEDICATED)(BROKERS=1))','((TYPE=EMON)(BROKERS=1))'# connection_brokers default value
*.control_files='/u01/app/oracle/oradata/cdb/control01.ctl'#Restore Controlfile
*.core_dump_dest='/u01/app/oracle/diag/rdbms/sbcdb/cdb/cdump'
*.db_block_size=8192
*.db_file_name_convert='/u01/app/oracle/oradata/cdb/','/u01/app/oracle/oradata/cdb/'
*.db_name='cdb'
*.db_unique_name='sbcdb'
*.diagnostic_dest='/u01/app/oracle'
*.enable_pluggable_database=TRUE
*.fal_server='CDB'
*.log_archive_config='DG_CONFIG=(cdb,sbcdb)'
*.log_archive_dest_1='location=/u01/app/arc'
*.log_buffer=7456K# log buffer update
*.log_file_name_convert='/u01/app/oracle/oradata/cdb/','/u01/app/oracle/oradata/cdb/'
*.open_cursors=300
*.optimizer_dynamic_sampling=2
*.optimizer_mode='ALL_ROWS'
*.pga_aggregate_target=585M
*.plsql_warnings='DISABLE:ALL'# PL/SQL warnings at init.ora
*.processes=640
*.query_rewrite_enabled='TRUE'
*.remote_login_passwordfile='EXCLUSIVE'
*.result_cache_max_size=9024K
*.sga_target=1760M
*.skip_unusable_indexes=TRUE
*.standby_file_management='AUTO'
*.undo_tablespace='UNDOTBS1'
建立目录:
mkdir -p /u01/app/oracle/admin/cdb/adump
mkdir -p /u01/app/oracle/oradata/cdb

3主备数据库tnsname.ora 配置

[oracle@prod05 admin]$ cat tnsnames.ora 

cdb =
(DESCRIPTION =
    (ADDRESS_LIST =(ADDRESS=(PROTOCOL= TCP)(HOST=prod04)(PORT=1521)))
    (CONNECT_DATA =
    (SERVER = DEDICATED)
    (SERVICE_NAME = cdb))
)

sbcdb =
(DESCRIPTION =
    (ADDRESS_LIST =(ADDRESS=(PROTOCOL = TCP)(HOST=prod05) (PORT=1521)))
    (CONNECT_DATA =
    (UR=A)
    (SERVER = DEDICATED)
    (SERVICE_NAME = sbcdb))
)

4,备库启动到nomount,使用rman 同步数据库

主数据库:cdb
备数据库:sbcdb

rman target sys/oracle@cdb auxiliary sys/oracle@sbcdb

Recovery Manager: Release 12.2.0.1.0 - Production on Wed Aug 29 14:47:36 2018

Copyright (c) 1982, 2017, Oracle and/or its affiliates.  All rights reserved.

connected to target database: CDB (DBID=2100050565)
connected to auxiliary database: CDB (not mounted)

RMAN> DUPLICATE TARGET DATABASE FOR STANDBY FROM ACTIVE DATABASE DORECOVER   NOFILENAMECHECK;

Starting Duplicate Db at 29-AUG-18
using target database control file instead of recovery catalog
allocated channel: ORA_AUX_DISK_1
channel ORA_AUX_DISK_1: SID=621 device type=DISK
current log archived

contents of Memory Script:
{
   backup as copy reuse
   passwordfile auxiliary format  '/u01/app/oracle/product/12.2.0/dbhome_1/dbs/orapwcdb'   ;
}
executing Memory Script

Starting backup at 29-AUG-18
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=254 device type=DISK
Finished backup at 29-AUG-18

contents of Memory Script:
{
   restore clone from service  'cdb' standby controlfile;
}
executing Memory Script

Starting restore at 29-AUG-18
using channel ORA_AUX_DISK_1

channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: restoring control file
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
output file name=/u01/app/oracle/oradata/cdb/control01.ctl
Finished restore at 29-AUG-18

contents of Memory Script:
{
   sql clone 'alter database mount standby database';
}
executing Memory Script

sql statement: alter database mount standby database

contents of Memory Script:
{
   set newname for tempfile  1 to 
 "/u01/app/oracle/oradata/cdb/temp01.dbf";
   set newname for tempfile  2 to 
 "/u01/app/oracle/oradata/cdb/pdbseed/temp012018-08-06_11-44-49-136-AM.dbf";
   set newname for tempfile  3 to 
 "/u01/app/oracle/oradata/cdb/pdb01/temp01.dbf";
   switch clone tempfile all;
   set newname for datafile  1 to 
 "/u01/app/oracle/oradata/cdb/system01.dbf";
   set newname for datafile  3 to 
 "/u01/app/oracle/oradata/cdb/sysaux01.dbf";
   set newname for datafile  4 to 
 "/u01/app/oracle/oradata/cdb/undotbs01.dbf";
   set newname for datafile  5 to 
 "/u01/app/oracle/oradata/cdb/pdbseed/system01.dbf";
   set newname for datafile  6 to 
 "/u01/app/oracle/oradata/cdb/pdbseed/sysaux01.dbf";
   set newname for datafile  7 to 
 "/u01/app/oracle/oradata/cdb/users01.dbf";
   set newname for datafile  8 to 
 "/u01/app/oracle/oradata/cdb/pdbseed/undotbs01.dbf";
   set newname for datafile  9 to 
 "/u01/app/oracle/oradata/cdb/pdb01/system01.dbf";
   set newname for datafile  10 to 
 "/u01/app/oracle/oradata/cdb/pdb01/sysaux01.dbf";
   set newname for datafile  11 to 
 "/u01/app/oracle/oradata/cdb/pdb01/undotbs01.dbf";
   set newname for datafile  12 to 
 "/u01/app/oracle/oradata/cdb/pdb01/users01.dbf";
   restore
   from  nonsparse   from service 
 'cdb'   clone database
   ;
   sql 'alter system archive log current';
}
executing Memory Script

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

renamed tempfile 1 to /u01/app/oracle/oradata/cdb/temp01.dbf in control file
renamed tempfile 2 to /u01/app/oracle/oradata/cdb/pdbseed/temp012018-08-06_11-44-49-136-AM.dbf in control file
renamed tempfile 3 to /u01/app/oracle/oradata/cdb/pdb01/temp01.dbf in control file

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

Starting restore at 29-AUG-18
using channel ORA_AUX_DISK_1

channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00001 to /u01/app/oracle/oradata/cdb/system01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:15
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00003 to /u01/app/oracle/oradata/cdb/sysaux01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:03
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00004 to /u01/app/oracle/oradata/cdb/undotbs01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00005 to /u01/app/oracle/oradata/cdb/pdbseed/system01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00006 to /u01/app/oracle/oradata/cdb/pdbseed/sysaux01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:03
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00007 to /u01/app/oracle/oradata/cdb/users01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00008 to /u01/app/oracle/oradata/cdb/pdbseed/undotbs01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00009 to /u01/app/oracle/oradata/cdb/pdb01/system01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:03
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00010 to /u01/app/oracle/oradata/cdb/pdb01/sysaux01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:03
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00011 to /u01/app/oracle/oradata/cdb/pdb01/undotbs01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting datafile backup set restore
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_AUX_DISK_1: restoring datafile 00012 to /u01/app/oracle/oradata/cdb/pdb01/users01.dbf
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
Finished restore at 29-AUG-18

sql statement: alter system archive log current
current log archived

contents of Memory Script:
{
   restore clone force from service  'cdb' 
           archivelog from scn  1459337;
   switch clone datafile all;
}
executing Memory Script

Starting restore at 29-AUG-18
using channel ORA_AUX_DISK_1

channel ORA_AUX_DISK_1: starting archived log restore to default destination
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: restoring archived log
archived log thread=1 sequence=29
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting archived log restore to default destination
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: restoring archived log
archived log thread=1 sequence=30
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
channel ORA_AUX_DISK_1: starting archived log restore to default destination
channel ORA_AUX_DISK_1: using network backup set from service cdb
channel ORA_AUX_DISK_1: restoring archived log
archived log thread=1 sequence=31
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:01
Finished restore at 29-AUG-18

datafile 1 switched to datafile copy
input datafile copy RECID=4 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/system01.dbf
datafile 3 switched to datafile copy
input datafile copy RECID=5 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/sysaux01.dbf
datafile 4 switched to datafile copy
input datafile copy RECID=6 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/undotbs01.dbf
datafile 5 switched to datafile copy
input datafile copy RECID=7 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdbseed/system01.dbf
datafile 6 switched to datafile copy
input datafile copy RECID=8 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdbseed/sysaux01.dbf
datafile 7 switched to datafile copy
input datafile copy RECID=9 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/users01.dbf
datafile 8 switched to datafile copy
input datafile copy RECID=10 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdbseed/undotbs01.dbf
datafile 9 switched to datafile copy
input datafile copy RECID=11 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdb01/system01.dbf
datafile 10 switched to datafile copy
input datafile copy RECID=12 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdb01/sysaux01.dbf
datafile 11 switched to datafile copy
input datafile copy RECID=13 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdb01/undotbs01.dbf
datafile 12 switched to datafile copy
input datafile copy RECID=14 STAMP=985445350 file name=/u01/app/oracle/oradata/cdb/pdb01/users01.dbf

contents of Memory Script:
{
   set until scn  1459516;
   recover
   standby
   clone database
    delete archivelog
   ;
}
executing Memory Script

executing command: SET until clause

Starting recover at 29-AUG-18
using channel ORA_AUX_DISK_1

starting media recovery

archived log for thread 1 with sequence 29 is already on disk as file /u01/app/arc/1_29_983447047.dbf
archived log for thread 1 with sequence 30 is already on disk as file /u01/app/arc/1_30_983447047.dbf
archived log for thread 1 with sequence 31 is already on disk as file /u01/app/arc/1_31_983447047.dbf
archived log file name=/u01/app/arc/1_29_983447047.dbf thread=1 sequence=29
archived log file name=/u01/app/arc/1_30_983447047.dbf thread=1 sequence=30
archived log file name=/u01/app/arc/1_31_983447047.dbf thread=1 sequence=31
media recovery complete, elapsed time: 00:00:01
Finished recover at 29-AUG-18
Finished Duplicate Db at 29-AUG-18

RMAN> 

5,主库开启日志传输

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(cdb,sbcdb)';
alter system set LOG_ARCHIVE_DEST_2='SERVICE=sbcdb ASYNC  VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=sbcdb';

6,备库接受并应用日志

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(cdb,sbcdb)';
启动日志应用
ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT;
关闭日志应用
ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;

7检查同步状态

日志同步状态:

SELECT MAX(SEQUENCE#), THREAD# FROM V$ARCHIVED_LOG -
WHERE RESETLOGS_CHANGE# = (SELECT MAX(RESETLOGS_CHANGE#) FROM V$ARCHIVED_LOG) -
GROUP BY THREAD#;


SELECT DESTINATION, STATUS, ARCHIVED_THREAD#, ARCHIVED_SEQ# -
FROM V$ARCHIVE_DEST_STATUS -
WHERE STATUS <> 'DEFERRED' AND STATUS <> 'INACTIVE';

8 ENABLED_PDBS_ON_STANDBY参数

启用这个参数意味着,可以指定部分PDB,复制到备库中。

The new ENABLED_PDBS_ON_STANDBY initialization parameter enables you to specify a subset of pluggable databases (PDBs) for replication on a physical standby of a multitenant container database (CDB). In releases prior to Oracle Database 12c Release 2 (12.2.0.1), you had to specify either all PDBs or none.
Parameter enabled_pdbs_on_standby and STANDBYS Option With Data Guard Subset Standby (文档 ID 2417018.1)

9 temp 表空间问题

temp 并不会复制到备及

处理方法:
alter tablespace temp add tempfile '/u01/app/oracle/oradata/cdb/pdb01/temp02.dbf' size 50m;
alter tablespace temp drop tempfile '/u01/app/oracle/oradata/cdb/pdb01/temp01.dbf';

10 pdb数据库创建删除命令

set linesize 100;
col name format a50;
select con_id,guid,name from V$CONTAINERS;
drop pluggable database pdb02  including datafiles;
create pluggable database pdb02 admin user pdbadmin identified by admin FILE_NAME_CONVERT=('pdbseed','pdb02');
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
Oracle 关系型数据库 语音技术
使用DataPump迁移非CDB到CDB数据库
Oralce 12c中的多租户数据库的启用,使得原来分布于多台服务器或者一台服务器上运行N多实例的情形需要进行整合。
1454 0
|
SQL 存储 关系型数据库
Oracle 12c CDB数据库中数据字典架构
数据字典就是元数据的集合,比如创建的表,列,约束,触发器等等这些都是元数据,需要保存到数据库中。
1457 0
|
关系型数据库 测试技术 数据库
【DATAGUARD 学习】如何停止standby数据库
主库:ORCL  备库:TESTDG           一般的,停止standby数据库之前,要先停用primary库,如果直接停用standby库,可能导致primary库也直接shutdown(最大保护模式)。
1206 0