共计 5017 个字符,预计需要花费 13 分钟才能阅读完成。
背景简介:
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'
*.log_archive_dest_2=
'service=orcl reopen=120 lgwr async valid_for=(online_logfiles,primary_role) db_unique_name=orcl'
*.log_archive_dest_state_2=
'enable'
*.log_archive_format=
'%t_%s_%r.dbf'
*.memory_target=1073741824
*.open_cursors=500
*.processes=150
*.remote_login_passwordfile=
'EXCLUSIVE'
*.resource_manager_plan=
''
*.standby_file_management=
'AUTO'
orcl1.instance_name=orcl1
orcl1.instance_number=1
orcl1.undo_tablespace=
'UNDOTBS1'
orcl1.thread=1
orcl1.local_listener=
'(address=(protocol=TCP)(HOST=192.168.100.103)(PORT=1521))'
-- 这里填写节点 1 的 VIP
*.remote_listener=
'(address=(protocol=TCP)(HOST=192.168.100.105)(PORT=1521))'
-- 这里填写 RAC 的 scanip
修改完毕后改名为 initorcl1.ora 并将之放在 $ORACLE_HOME/dbs 目录下。
3. 修改 tnsnames.ora 文件
修改单实例主库的 tnsnames.ora 文件如下,并将之拷贝到备库所有节点。
ORCL =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.100)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
ORCL_ST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.101)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SID = orcl1)
)
)
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'
; -- 这里填写备份所在的目录路径。恢复备份:
run {
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
allocate channel c4 type disk;
allocate channel c5 type disk;
allocate channel c6 type disk;
allocate channel c7 type disk;
allocate channel c8 type disk;
set
newname
for
datafile 1 to
'+DATA/orcl/datafile/system01.dbf'
;
set
newname
for
datafile 2 to
'+DATA/orcl/datafile/sysaux01.dbf'
;
set
newname
for
datafile 3 to
'+DATA/orcl/datafile/undotbs101.dbf'
;
set
newname
for
datafile 4 to
'+DATA/orcl/datafile/users01.dbf'
;
...
-- 主库有多少个数据文件,在这里写多少行,格式为:
--
set
newname
for
datafile file_id to
'file_name'
;
restore database;
switch
datafile all;
}
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 和添加节点的操作,此外还要设置合适的备份及归档清除计划,步骤较繁琐,在这里不再详述。
更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-06/144605.htm