热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

通过RMANDUPLICATE...FROMACTIVEDATABASE创建dataguard(fororacle11g)

通过RMANDUPLICATE...FROMACTIVEDATABASE创建dataguard(fororacle11g)oracle10g可以通过基于备份的rmanDUPLICATE实现dataguard,通过步骤需要对数据库进行备份,并在standby侧进行数据库的恢复。而...

通过RMAN DUPLICATE...FROM ACTIVE DATABASE创建dataguard(for oracle 11g)
 
oracle 10g可以通过基于备份的rman DUPLICATE实现dataguard,通过步骤需要对数据库进行备份,并在standby侧进行数据库的恢复。而到了11g,oracle推出了Duplicate From Active Database技术,不需要再对数据库进行rman备份恢复,一切动作都通过网络自动完成。
下面是具体的实现例子:
primary db:hrdbprim
standby db:standby(由于是三个节点的rac,实例名为standby1)
  www.2cto.com  
一、primary侧的环境准备:
1,确保数据库归档状态
 
[sql] 
SQL> select log_mode from v$database;  
  
LOG_MODE  
------------  
ARCHIVELOG  
 
2,Enable force logging 
[sql] 
SQL> ALTER DATABASE FORCE LOGGING;  
  
Database altered.  
 
3,生成standby redolog
[sql] 
SQL> alter database add standby logfile '/oracle/app/oracle/oradata/hrdbprim/redo11.log' size 50m;  
  
Database altered.  
 
4,修改primary参数文件spfile,需要设置以下8个参数
[sql] 
SQL> alter system set LOG_ARCHIVE_COnFIG='DG_COnFIG=(hrdbprim,standby)';  
    www.2cto.com  
System altered.  
  
SQL> alter system set LOG_ARCHIVE_DEST_1='LOCATION=/oracle/app/oracle/oradata/hrdbprim/ VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=hrdbprim';  
  
System altered.  
  
SQL> alter system set LOG_ARCHIVE_DEST_2='SERVICE=standby LGWR ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=standby';  
  
System altered.  
  
SQL> alter system set LOG_ARCHIVE_DEST_STATE_1=ENABLE;  
  
System altered.  
  
SQL> alter system set FAL_SERVER=standby;  
  
System altered.  
  
SQL> alter system set FAL_CLIENT=standby;  
  
System altered.  
    www.2cto.com  
SQL> alter system set DB_FILE_NAME_COnVERT='/oracle/app/oracle/oradata/hrdbprim/','+DATA/standby/datafile/' scope=spfile;  
  
System altered.  
  
SQL> alter system set LOG_FILE_NAME_COnVERT='/oracle/app/oracle/oradata/hrdbprim/','+DATA/standby/onlinelog/' scope=spfile;  
  
System altered.  
二、修改sql*net相关文件,确保网络环境准备,确保互相tnsping通
listener.ora
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
     (GLOBAL_DBNAME = standby)
     (ORACLE_HOME = /oracle/app/oracle/product/11.2.0/db_1)
     (SID_NAME = standby3)
    )
   )
 
LISTENER =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.4.124.235)(PORT = 1521))
  )
 
  www.2cto.com  
tnsnames.ora
 
hrdbprim = 
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.4.124.239)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = hrdbprim)
    )
  )
standby =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.4.124.235)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = standby)(UR=A)
    )
  )
三、创建standby数据库
 
1,password密码文件;既可以从primary复制改名,也可以重新生成一个,主要要保持sys口令一致,这里采用复制方式
sftp ...
mv orapwhrdbprim orapwstandby
2,新建pfile文件,注意pfile要放在$ORACLE_HOME/dbs目录,否则启动时需要指定pfile文件,注意启动时必须使用pfile文件启动,否者无法复制
vi initstandby3.ora
 
DB_NAME=standby
DB_UNIQUE_NAME=standby
*.audit_file_dest='/oracle/app/oracle/admin/standby/adump'
*.control_files='+DATA/standby/controlfile/control01.ctl','+FRA/standby/controlfile/control02.ctl'
*.db_create_file_dest='+DATA'
*.db_block_size=8192
*.db_recovery_file_dest='+FRA'
*.db_recovery_file_dest_size=10G
 
3,创建相关目录,用来放datafile和trace file
mkdir -p /oracle/app/oracle/admin/standby/adump
ASMCMD> mkdir standby
ASMCMD> cd standby
ASMCMD> mkdir controlfile
ASMCMD> pwd
+data/standby
ASMCMD> cd controlfile
ASMCMD> pwd
+data/standby/controlfi
  www.2cto.com  
4,启动数据库到nomount状态
 
standby>startup nomount pfile = '/oracle/app/oracle/product/11.2.0/db_1/dbs/initstandby3.ora';
ORACLE 例程已经启动。
 
Total System Global Area  304861184 bytes
Fixed Size                  2225872 bytes
Variable Size             159385904 bytes
Database Buffers          134217728 bytes
Redo Buffers                9031680 bytes
 
5,测试数据库连接问题
SQL> connect sys/"pl,12345"@standby as sysdba;
ERROR:
ORA-12528: TNS:listener: all appropriate instances are blocking new connections
说明数据库没有启动到mount状态,监听器blocked
通过tnsnames.ora中添加(UR=A)解决,且最好使用listener.ora静态注册
 
6,primary主机运行如下命令,此处连接必须使用网络连接符,否者报错
 
[sql] 
RMAN> run {  
allocate channel prmy1 type disk;  
allocate channel prmy2 type disk;  
allocate channel prmy3 type disk;  
allocate channel prmy4 type disk;  
allocate auxiliary channel stby type disk;  
  
duplicate target database for standby from active database  
spfile    www.2cto.com  
  parameter_value_convert 'hrdbprim','standby'  
  set db_unique_name='standby'  
  set db_file_name_cOnvert='/oracle/app/oracle/oradata/hrdbprim/','+DATA/standby/datafile/'  
  set log_file_name_cOnvert='/oracle/app/oracle/oradata/hrdbprim/','+DATA/standby/onlinelog/'  
  set control_files='+DATA/standby/controlfile/control01.ctl','+FRA/standby/controlfile/control02.ctl'  
  set log_archive_max_processes='5'  
  set fal_client='standby'  
  set fal_server='hrdbprim'  
  set standby_file_management='AUTO'  
  set log_archive_cOnfig='dg_cOnfig=(hrdbprim,standby)'  
  set log_archive_dest_1='service=hrdbprim ASYNC valid_for=(ONLINE_LOGFILE,PRIMARY_ROLE) db_unique_name=hrdbprim'  
;  
}  
.........  
7,standby数据库,开启dataguard
 
sys@STANDBY3(dtydb5)> alter database recover managed standby database disconnect from session;
 
数据库已更改。
 
8,对于active dataguard,可以再使用如下命令
 
[sql] 
sys@STANDBY3(dtydb5)> alter database recover managed standby database cancel;  
  
数据库已更改。  
  
sys@STANDBY3(dtydb5)> alter database open;  
  
数据库已更改。  
  
sys@STANDBY3(dtydb5)> alter database recover managed standby database disconnect;  
  
数据库已更改。  
  
sys@STANDBY3(dtydb5)> alter database recover managed standby database using current logfile disconnect from session;  
    www.2cto.com  
数据库已更改。  
 
四、测试ADG结果
 
恢复单节点到rac数据库,注册到CRS,参见上篇文章
 
备注:注意事项:
a、standby监听器必须是静态监听
b、db_file_name_convert要正确设置,否者会报错ORA-17628, ORA-19505 
 
参考资料:
    RMAN 'Duplicate From Active Database' Feature in 11G [ID 452868.1]
    Step by Step Guide on Creating Physical Standby Using RMAN DUPLICATE...FROM ACTIVE DATABASE [ID 1075908.1]
    ORA-17628, ORA-19505 during RMAN DUPLICATE FROM ACTIVE [ID 1331986.1]
 
 
作者 hijk139

推荐阅读
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • Postgresql备份和恢复的方法及命令行操作步骤
    本文介绍了使用Postgresql进行备份和恢复的方法及命令行操作步骤。通过使用pg_dump命令进行备份,pg_restore命令进行恢复,并设置-h localhost选项,可以完成数据的备份和恢复操作。此外,本文还提供了参考链接以获取更多详细信息。 ... [详细]
  • REVERT权限切换的操作步骤和注意事项
    本文介绍了在SQL Server中进行REVERT权限切换的操作步骤和注意事项。首先登录到SQL Server,其中包括一个具有很小权限的普通用户和一个系统管理员角色中的成员。然后通过添加Windows登录到SQL Server,并将其添加到AdventureWorks数据库中的用户列表中。最后通过REVERT命令切换权限。在操作过程中需要注意的是,确保登录名和数据库名的正确性,并遵循安全措施,以防止权限泄露和数据损坏。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 本文介绍了如何使用Power Design(PD)和SQL Server进行数据库反向工程的方法。通过创建数据源、选择要反向工程的数据表,PD可以生成物理模型,进而生成所需的概念模型。该方法适用于SQL Server数据库,对于其他数据库是否适用尚不确定。详细步骤和操作说明可参考本文内容。 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • IT方面的论坛太多了,有综合,有专业,有行业,在各个论坛里混了几年,体会颇深,以前是论坛哪里人多 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • 本文讲述了孙悟空写给白骨精的信件引发的思考和反省。孙悟空在信中对自己的行为进行了反思,认识到自己胡闹的行为并没有给他带来实际的收获。他也揭示了西天取经的真相,认为这是玉皇、菩萨设下的一场陷阱。他还提到了师傅的虚伪和对自己的实心话,以及自己作为师傅准备提拔的对象而被派下来锻炼的经历。他认为路上的九九八十一难也都是菩萨算计好的,唐僧并没有真正的危险。最后,他提到了观音菩萨在关键时刻的指导。这封信件引发了孙悟空对自己行为的思考和反省,对西天取经的目的和自己的角色有了更深入的认识。 ... [详细]
  • Windows2003 IIS上设置301定向,实现不带www域名跳转带www域名的方法
    打开IIS,建一个网站,主机头用不带www的域名,随便指向一个目录。然后在这个网站上点右键,属性--主目录--重定向到URL如图ÿ ... [详细]
  • 本文介绍了在Ubuntu下制作deb安装包及离线安装包的方法,通过备份/var/cache/apt/archives文件夹中的安装包,并建立包列表及依赖信息文件,添加本地源,更新源列表,可以在没有网络的情况下更新系统。同时提供了命令示例和资源下载链接。 ... [详细]
  • 本文讨论了读书的目的以及学习算法的重要性,并介绍了两个算法:除法速算和约瑟夫环的数学算法。同时,通过具体的例子和推理,解释了为什么x=x+k序列中的第一个人的位置为k,以及序列2和序列3的关系。通过学习算法,可以提高思维能力和解决问题的能力。 ... [详细]
author-avatar
徐徐回忆_545
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有