DataGuard单实例到RAC搭建

时间:2017-07-08 13:53

DataGuard 单实例到RAC搭建

本文为针对一次Windows平台RAC数据库迁移至Linux平台RAC的笔记,基本步骤为:

1.搭建Windows RAC到Linux 单实例数据库的DataGuard

2.做switchover,将备库IP修改为原RAC数据库的scanip

3.搭建单实例到Linux RAC的DataGuard(scanip与原RAC不同),并做switchover切换

4.修改RAC数据库scanip为为原RAC的scanip,并将单节点备库IP改为原备库IP,修改监听和tnsnames.ora文件,恢复灾备备库运转。

数据库版本为Oracle 11.2.0.4,RAC为Windows平台的两节点,数据量约为2.5T,停机时间约为15min。

本文只包含步骤3的相关操作,即描述如何搭建单节点到RAC的DataGuard。本例中RAC两节点IP为192.168.100.101/102,VIP为103/104,scanip为105,单实例的主库IP为192.168.100.100

实施步骤:

1.准备阶段:

本阶段主要做一些数据库的前期准备配置,如归档是否开启等操作。

单实例主库:

1)select force_logging from v$database; --确保主库开启force logging

2)archive log list; --确保主库为归档模式

3)在单实例主库添加standby redo,好处是做switchover时无需再添加stanbyredo,而且备库使用此全备后也会自动创建standby redo而无需再手动添加,一般standby redo比正常redo多一组即可,每组member个数随意,一般1个即可。

RAC备库:

1)在两节点按正常步骤安装RAC,但不建库,需要提前建好+DATA磁盘组。

2)为节点1添加数据库和实例:

srvctl add database -d orcl_st -n orcl -o $ORACLE_HOME -s open -a "DATA,FRA" -r physical_standby

srvctl add instance -d orcl_st -i orcl1 -n node1

2.参数文件:

主库采用在线修改的方式:

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(orcl,orcl_st)' scope=both sid='*'

alter system set LOG_ARCHIVE_DEST_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=orcl' scope=both sid='*'

alter system set LOG_ARCHIVE_DEST_2='SERVICE=orcl_st reopen=120 lgwr async VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=orcl_st' scope=both sid='*'

alter system set fal_server=orcl_st scope=both sid='*'

alter system set db_file_name_convert='/oradata/orcl/datafile','+data/orcl/datafile','/oradata/orcl/tempfile','+data/orcl/TEMPFILE' scope=spfile sid='*'

alter system set log_file_name_convert='/oradata/orcl/onlinelog','+data/orcl/ONLINELOG' scope=spfile sid='*'

alter system set standby_file_management=AUTO scope=both sid='*' 

注意这里log_file_name_convert并没有将db_recovery_file_dest下的路径也一并映射,这是因为主库闪回区内的onlinelog将会被自动映射为备库闪回区的相关位置。

如果数据文件较为散乱,则需要将所有数据文件的路径全部映射至'+data/orcl/datafile',方便管理。

备库修改参数文件:

    *.__oracle_base='/u01/app/oracle'#ORACLE_BASE set from environment 

    *.audit_file_dest='/u01/app/oracle/admin/orcl/adump' --此目录需提前创建 

    *.audit_trail='db' 

    *.compatible='11.2.0.4.0' 

    *.cluster_database=true 

    *.control_files='+DATA/orcl/controlfile/control01.ctl'#Restore Controlfile 

    *.db_block_size=8192 

    *.db_domain='' 

    *.db_name='orcl' 

    *.db_unique_name='orcl_st' 

    *.db_recovery_file_dest='+FRA' 

    *.db_recovery_file_dest_size=5218762752 

    *.diagnostic_dest='/u01/app/oracle' 

    *.fal_server='ORCL' 

    *.log_archive_config='DG_CONFIG=(orcl,orcl_st)' 

    *.log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=orcl_st' 

  • A+
所属分类:Linux