本文将介绍如何给rac搭建单节点的dg,欧博以及如何对其进行角色转换。预先具备的知识(rac搭建,单实例-单实例dg搭建) 二、实验环境介绍主库rac(已安装rac,并已有数据库orcl) 从库(已安装单实例数据库软件,无数据库实例) ** 以下所有主库操作都在节点1上做,如果需要在节点2上做的,我会标明 1. 主库打开归档模式,并强制写日志先查看数据库的归档状态以及是否开启强制写日志,从下图可以看到目前数据库并没有打开归档,也没有开启强制写日志 数据库在mount状态下打开归档 强制日志写,数据库在open状态就能修改 SQL> startup; # 当节点1open完毕后,欧博allbet在节点2上打开数据库 再来查看数据库的归档状态以及是否开启强制写日志 SQL> alter system set log_archive_config='dg_config=(orcl,orcldg)' sid='*'; # orcl是主库的db_unique_name,orcldg是从库的db_unique_name 3. 主库设置远程归档SQL> alter system set log_archive_dest_3='service=orcldg valid_for=(online_logfiles,primary_role) db_unique_name=orcldg' sid='*'; 4. 将主库的口令文件传送给从库[oracle@rac1 ~]$ scp $ORACLE_HOME/dbs/orapw$ORACLE_SID 192.168.56.102:$ORACLE_HOME/dbs/orapworcldg 5. 从库准备参数文件这里参数文件跟给单实例搭建单实例dg没什么区别,所以不做具体介绍 *.audit_file_dest='/u01/app/oracle/admin/orcldg/adump' *.audit_trail='db' *.compatible='11.2.0.4.0' *.control_files='/u01/app/oracle/oradata/orcldg/controlfile/control01.ctl' *.db_block_size=8192 *.db_domain='' *.db_name='orcl' *.diagnostic_dest='/u01/app/oracle' *.log_archive_config='dg_config=(orcl,orcldg)' *.log_archive_dest_2='location=/u01/app/oracle/oradata/orcldg/archstdlog/ valid_for=(standby_logfiles,standby_role) db_unique_name=orcldg' *.memory_target=838860800 *.open_cursors=300 *.processes=150 *.remote_login_passwordfile='exclusive' *.undo_tablespace='UNDOTBS1' standby_file_management=auto # 该参数默认值是manual,需要将其改为auto,表示主库的数据文件发生修改(如新建,重命名等),相应地从库也做相应修改 db_unique_name='orcldg' db_file_name_convert='+DATA/orcl/datafile/','/u01/app/oracle/oradata/orcldg/datafile/','+DATA/orcl/tempfile/','/u01/app/oracle/oradata/orcldg/tempfile/' log_file_name_convert='+DATA/orcl/onlinelog/','/u01/app/oracle/oradata/orcldg/onlinelog/' 6. 从库中准备相关目录[oracle@oradg ~]$ mkdir -p /u01/app/oracle/admin/orcldg/adump [oracle@oradg ~]$ export ORACLE_SID=orcldg 因为采用duplicate方式复制主库数据,所以需要将从库配置为静态注册的形式 [oracle@oradg ~]$ vi $ORACLE_HOME/network/admin/listener.ora SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = orcldg) (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_1) (SID_NAME = orcldg) ) ) LISTENER = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.102)(PORT = 1521)) ) [oracle@oradg ~]$ lsnrctl start 9. 主库配置服务命名# 两个节点都要设置 orcldg = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.102)(PORT = 1521)) ) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcldg) ) )
# 这里我的主库的sys密码是123456,从库与主库一致 rman连接主库和从库 RMAN> duplicate target database for standby from active database; 12. 从库添加standbylog添加的日志大小跟主库的onlinelog保持一致,数量多两组(主库的onlinelog信息查看v$log) [oracle@oradg ~]$ mkdir -p /u01/app/oracle/oradata/orcldg/standbylog/ SQL> alter database recover managed standby database disconnect from session; 14. 主库切换归档SQL> alter system switch logfile; 15. 打开从库当从库应用归档一段时间后,就关闭应用归档日志,打开从库。 主库做修改 从库查询 至此,给rac搭建一个单实例的dg就已经做完了,跟单实例搭建单实例的dg没什么区别。接下来介绍如何切换。 四、主从切换准备 17. 主库添加standby logfile归档路径使用grid账号,创建归档路径 使用sys数据库账号,修改数据库参数 添加的日志的大小跟主库的onlinelog保持一致,数量多两组(主库的onlinelog信息查看v$log) SQL> alter system set standby_file_management=auto sid='*'; 到这里,主库转换为备库的准备工作已完成! 20. 从库配置tnsnames.ora这里的配置tnsnames.ora的目的是,当原从库转变为新主库之后,原主库变为新从库,新主库需要给新从库发送归档日志,所以这里的tnsnames要指向新从库,又由于dg库应用归档只能在一个节点上, 所以toorcl只指向节点1。 [oracle@oradg ~]$ vi $ORACLE_HOME/network/admin/tnsnames.ora toorcl = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.11)(PORT = 1521)) ) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl) ) ) 21. 从库为onlinelog设置归档路径[oracle@oradg ~]$ mkdir -p /u01/app/oracle/oradata/orcldg/archivelog SQL> alter system set log_archive_dest_1='location=/u01/app/oracle/oradata/orcldg/archivelog/ valid_for=(online_logfiles,primary_role) db_unique_name=orcldg'; 22. 从库设置远程归档参数SQL> alter system set log_archive_dest_3='service=toorcl valid_for=(online_logfiles,primary_role) db_unique_name=orcl'; 到这里,从库转为主库的准备工作已完成! 四、主从切换 23. 查看主库的角色转换状态SQL> select database_role,switchover_status from v$database; 24. 在节点1上主转从 集群在做角色转换时,只能有一个实例是打开状态,其余都要关闭,所以将节点2的实例关闭。 在节点1上执行以下命令,将主库转为从库,并且关闭实例 SQL> select database_role,switchover_status from v$database; 如果是"NOT ALLOWED"表示归档还没有应用完成,可以等待一段时间 如果日志全部应用了再查看角色转换状态 如果角色转换状态是TO PRIMARY,那么表示可以进行角色转换 执行从转主的命令,命令执行成功后,数据库的状态会变为mount 在节点1和节点2上 节点1上应用归档 节点3上切换归档 主库做修改 从库查询 如果发现日志传不到备库的话可以在主库通过以下命令查看错误原因 SQL> select dest_id,dest_name,log_sequence,status,error from v$archive_dest; 如果报上面的错误的话,可以把归档开关重启一下即可 1. dg的切换需要停掉所有的应用,并把数据库的所有连接全部kill掉,账号全锁(此举是为了防止切换过程中有用户登录),切换完成后再解锁 |