DataGuard单实例到RAC搭建

[[195756]]

本文为针对一次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.参数文件:

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

  1. alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(orcl,orcl_st)' scope=both sid='*'
  2. 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='*'
  3. 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='*'
  4. alter system set fal_server=orcl_st scope=both sid='*'
  5. alter system set db_file_name_convert='/oradata/orcl/datafile','+data/orcl/datafile','/oradata/orcl/tempfile','+data/orcl/TEMPFILE' scope=spfile sid='*'
  6. alter system set log_file_name_convert='/oradata/orcl/onlinelog','+data/orcl/ONLINELOG' scope=spfile sid='*'
  7. alter system set standby_file_management=AUTO scope=both sid='*' 

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

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

备库修改参数文件:

  1.     *.__oracle_base='/u01/app/oracle'#ORACLE_BASE set from environment 
  2.     *.audit_file_dest='/u01/app/oracle/admin/orcl/adump' --此目录需提前创建 
  3.     *.audit_trail='db' 
  4.     *.compatible='11.2.0.4.0' 
  5.     *.cluster_database=true 
  6.     *.control_files='+DATA/orcl/controlfile/control01.ctl'#Restore Controlfile 
  7.     *.db_block_size=8192 
  8.     *.db_domain='' 
  9.     *.db_name='orcl' 
  10.     *.db_unique_name='orcl_st' 
  11.     *.db_recovery_file_dest='+FRA' 
  12.     *.db_recovery_file_dest_size=5218762752 
  13.     *.diagnostic_dest='/u01/app/oracle' 
  14.     *.fal_server='ORCL' 
  15.     *.log_archive_config='DG_CONFIG=(orcl,orcl_st)' 
  16.     *.log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=orcl_st' 
  17.     *.log_archive_dest_2='service=orcl reopen=120 lgwr async valid_for=(online_logfiles,primary_role) db_unique_name=orcl' 
  18.     *.log_archive_dest_state_2='enable' 
  19.     *.log_archive_format='%t_%s_%r.dbf' 
  20.     *.memory_target=1073741824 
  21.     *.open_cursors=500 
  22.     *.processes=150 
  23.     *.remote_login_passwordfile='EXCLUSIVE' 
  24.     *.resource_manager_plan='' 
  25.     *.standby_file_management='AUTO' 
  26.     orcl1.instance_name=orcl1 
  27.     orcl1.instance_number=1 
  28.     orcl1.undo_tablespace='UNDOTBS1' 
  29.     orcl1.thread=1 
  30.     orcl1.local_listener='(address=(protocol=TCP)(HOST=192.168.100.103)(PORT=1521))' --这里填写节点1的VIP 
  31.  
  32. *.remote_listener='(address=(protocol=TCP)(HOST=192.168.100.105)(PORT=1521))' --这里填写RAC的scanip  

修改完毕后改名为initorcl1.ora并将之放在$ORACLE_HOME/dbs目录下。

3.修改tnsnames.ora文件

修改单实例主库的tnsnames.ora文件如下,并将之拷贝到备库所有节点。

  1. ORCL = 
  2.   (DESCRIPTION = 
  3.     (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.100)(PORT = 1521)) 
  4.     (CONNECT_DATA = 
  5.       (SERVER = DEDICATED) 
  6.       (SERVICE_NAME = orcl) 
  7.     ) 
  8.   ) 
  9.  
  10.   
  11. ORCL_ST = 
  12.   (DESCRIPTION = 
  13.     (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.101 )(PORT = 1521)) 
  14.     (CONNECT_DATA = 
  15.       (SERVER = DEDICATED) 
  16.       ( SID = orcl1) 
  17.     ) 
  18.   )  

4.密码文件

将单实例主库的密码文件orapw<$ORACLE_SID>拷贝至备库所有节点,并改名为orapworcl1和orapworcl2

5.在主库做数据库全备并拷贝至备库节点1。(略)

在做这一步之前确保主库的备份计划已被停止,或rman中ARCHIVELOG DELETION POLICY被设置为applied on standby;

6.待备份传送至备库之后,在主库做standby控制文件的备份

backup current controlfile for standby format ‘xxx’;

7.将备份的standby控制文件拷贝至备库节点1。

8.使用备库参数文件将节点1实例启动至nomount状态。

startup nomount;

9.在备库节点1使用RMAN还原stanby控制文件。

restore standby controlfile from ‘xxx’; –这里xxx路径为第7步中standby控制文件的位置。

alter database mount;

10.在备库注册备份集并恢复数据文件。

catalog start with ‘xxx’; –这里填写备份所在的目录路径。恢复备份:

  1. run { 
  2. allocate channel c1 type disk; 
  3. allocate channel c2 type disk; 
  4. allocate channel c3 type disk; 
  5. allocate channel c4 type disk; 
  6. allocate channel c5 type disk; 
  7. allocate channel c6 type disk; 
  8. allocate channel c7 type disk; 
  9. allocate channel c8 type disk; 
  10. set newname for datafile 1 to '+DATA/orcl/datafile/system01.dbf'
  11. set newname for datafile 2 to '+DATA/orcl/datafile/sysaux01.dbf'
  12. set newname for datafile 3 to '+DATA/orcl/datafile/undotbs101.dbf'
  13. set newname for datafile 4 to '+DATA/orcl/datafile/users01.dbf'
  14. ... 
  15. --主库有多少个数据文件,在这里写多少行,格式为: 
  16. --set newname for datafile file_id to 'file_name'; 
  17. restore database
  18. switch datafile all
  19.  

11.以上操作完成后,在备库节点1开启监听。

netca或者netmgr都可以,pmon进程会自动将节点1的实例注册至监听,默认的service_name为db_unique_name,本例中为orcl_st。

12.在备库开启MRP进程(此时为mount状态)

ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT;;

取消MRP的语句为:

ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;

13.观察备库节点1的alert日志,获知同步进度。

14.待追增量完毕后,取消MRP进程,打开备库,重启MRP进程。

以上就是搭建单实例到RAC的DataGuard的完整步骤,后期还需要做switch over、修改db_unique_name以及修改scanip和添加节点的操作,此外还要设置合适的备份及归档清除计划,步骤较繁琐,在这里不再详述。 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/261310.html<

(0)
运维的头像运维
上一篇2025-05-03 14:09
下一篇 2025-05-03 14:10

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注