DBCA命令行搭建Oracle ADG的流程


Posted in Oracle onJune 11, 2021

前言

Oracle Data Guard是Oracle MAA(Maximum Availability Architecture)中的成员之一。从Oracle 7i版本开始推出STANDBY DATABASE的概念,慢慢受到大家的欢迎。随着Oracle数据库版本的更迭,搭建备库的方式多种多样。今天介绍一种创建物理备库的新方式,从12C版本开始推出:使用 DBCA 命令行。

DBCA命令行搭建Oracle ADG的流程

dbca -createDuplicateDB -createAsStandby -dbUniqueName

优缺点:方便快捷,搭建速度较快。但是会影响主库的性能,执行过程报错不方便排查。

具体命令可参考:

dbca -silent -createDuplicateDB
    -gdbName global_database_name
    -primaryDBConnectionString easy_connect_string_to_primary
    -sid database_system_identifier
    [-createAsStandby 
        [-dbUniqueName db_unique_name_for_standby]]
    [-customScripts scripts_list]

更详细参数可参考The createDuplicateDB command creates a duplicate of an Oracle database.

DBCA命令行搭建Oracle ADG的流程

12.2.0.1开始支持DBCA创建物理备库:

主库必须是单机环境,非RAC数据库。

主库必须是非CDB环境。

18c之后,以上限制已经取消,支持主库是CDB和RAC环境。

一、环境准备

环境安装过程忽略,可参考:

30分钟!一键部署Oracle 19C单机CDB+PDB

本次测试尽量按照生产环境升级进行模拟:

节点 主机版本 主机名 实例名 Oracle版本 IP地址
rac01 rhel7.9 rac01 cdb19c 19.3.0(补丁 29585399) 10.211.55.100
rac02 rhel7.9 rac02 orcl+cdb19c 19.3.0(补丁 29585399) 10.211.55.101
备库 rhel7.9 dbca_stby 不创建实例 19.3.0(补丁 29585399) 10.211.55.110

注意:

1、db_unique_name主备库不能相同。

2、db_name主备库需保持一致。

3、主备库DB版本需保持一致。

Oracle测试环境安装:

可参考:DBA运维福音:10分钟,Linux一行命令安装Oracle数据库

主库RAC环境一键安装:

./OracleShellInstall.sh -i 10.211.55.100 `#Public ip`\
-n rac `# hostname`\
-c TRUE `# cdb`\
-pb orcl `# pdb`\
-o cdb19c `# oraclesid`\
-rs oracle `# root password`\
-op oracle `# oracle password`\
-gp oracle `# grid password`\
-b /u01/app `# install basedir`\
-s AL32UTF8 `# characterset`\
-pb1 10.211.55.100 -pb2 10.211.55.101 `# node public ip`\
-vi1 10.211.55.102 -vi2 10.211.55.103 `# node virtual ip`\
-pi1 1.1.1.1 -pi2 1.1.1.2 `# node private ip`\
-si 10.211.55.105 `# scan ip`\
-dd /dev/sdc `# asm data disk`\
-od /dev/sdb `# asm ocr disk`\
-or EXTERNAL `# asm ocr redundancy`\
-dr EXTERNAL `# asm data redundancy`\
-on OCR `# asm ocr diskgroupname`\
-dn DATA `# asm data diskgroupname`\
-puf eth0 -prf eth1 `# network fcname`\
-tsi 10.211.55.200 `# timeserver`\
-gpa 32545008 `# Grid PSU NUMBER`

DBCA命令行搭建Oracle ADG的流程

备库一键安装:(备库仅安装ORACLE软件,不建库)

./OracleShellInstall.sh -i 10.211.55.110 -n dbca_stby -o cdb19c -opa 32545013 -w Y

DBCA命令行搭建Oracle ADG的流程

二、ADG搭建准备

a.配置hosts文件

主库:

cat <<EOF >> /etc/hosts
##FOR DG BEGIN
10.211.55.110 dbca_stby
##FOR DG END
EOF

DBCA命令行搭建Oracle ADG的流程DBCA命令行搭建Oracle ADG的流程

备库:

cat <<EOF >> /etc/hosts
##FOR DG BEGIN
10.211.55.100 rac01
10.211.55.101 rac02
10.211.55.105 rac-scan
##FOR DG END
EOF

DBCA命令行搭建Oracle ADG的流程

b.配置静态监听和TNS

listener.ora增加静态监听:

grid用户执行:

rac01

cat <<EOF >> $TNS_ADMIN/listener.ora
##FOR DG BEGIN
SID_LIST_LISTENER =
	(SID_LIST =
		(SID_DESC =
			(GLOBAL_DBNAME = cdb19c)
			(ORACLE_HOME = /u01/app/oracle/product/19.3.0/db)
			(SID_NAME = cdb19c1)
		)
	)
##FOR DG END
EOF

DBCA命令行搭建Oracle ADG的流程

rac02

cat <<EOF >> $TNS_ADMIN/listener.ora
##FOR DG BEGIN
SID_LIST_LISTENER =
	(SID_LIST =
		(SID_DESC =
			(GLOBAL_DBNAME = cdb19c)
			(ORACLE_HOME = /u01/app/oracle/product/19.3.0/db)
			(SID_NAME = cdb19c2)
		)
	)
##FOR DG END
EOF

DBCA命令行搭建Oracle ADG的流程

备库

cat <<EOF >>$TNS_ADMIN/listener.ora
##FOR DG BEGIN
SID_LIST_LISTENER =
(SID_LIST =
	(SID_DESC =
		(GLOBAL_DBNAME = cdb19c_stby)
		(ORACLE_HOME = /u01/app/oracle/product/19.3.0/db)
		(SID_NAME = cdb19c_stby)
	)
)
##FOR DG END
EOF

DBCA命令行搭建Oracle ADG的流程

重启监听

#主库RAC重启监听
srvctl stop listener
srvctl start listener

##备库重启监听
lsnrctl start

DBCA命令行搭建Oracle ADG的流程DBCA命令行搭建Oracle ADG的流程DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程

tnsnames.ora增加TNS:

oracle用户执行:

cat <<EOF >> $TNS_ADMIN/tnsnames.ora
##FOR DG BEGIN
CDB19C =
(DESCRIPTION =
	(ADDRESS_LIST =
		(ADDRESS = (PROTOCOL = TCP)(HOST = rac-scan)(PORT = 1521))
	)
	(CONNECT_DATA =
		(SERVICE_NAME = cdb19c)
	)
)
CDB19C1 =
(DESCRIPTION =
	(ADDRESS_LIST =
		(ADDRESS = (PROTOCOL = TCP)(HOST = rac01)(PORT = 1521))
	)
	(CONNECT_DATA =
		(SERVICE_NAME = cdb19c)
	)
)
CDB19C2 =
(DESCRIPTION =
	(ADDRESS_LIST =
		(ADDRESS = (PROTOCOL = TCP)(HOST = rac02)(PORT = 1521))
	)
	(CONNECT_DATA =
		(SERVICE_NAME = cdb19c)
	)
)
CDB19C_STBY =
(DESCRIPTION =
	(ADDRESS_LIST =
		(ADDRESS = (PROTOCOL = TCP)(HOST = dbca_stby)(PORT = 1521))
	)
	(CONNECT_DATA =
		(SERVICE_NAME = cdb19c_stby)
	)
)
##FOR DG BEGIN
EOF

tnsping测试连通性:

tnsping cdb19c
tnsping cdb19c1
tnsping cdb19c2
tnsping cdb19c_stby

DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程

c.主库配置参数

SQL> select force_logging,log_mode,cdb from gv$database;

FORCE_LOGGING		LOG_MODE     CDB
--------------------------------------- 
YES					ARCHIVELOG   YES

如果没有开启强制日志:

alter database force logging;

如果没有开启归档日志:

shutdown immediate
startup mount
alter database archivelog;
alter database open;
alter pluggable database all open;

DBCA命令行搭建Oracle ADG的流程

d.主库添加stanby log文件

set line222
col member for a60
select t2.thread#,t1.group#,t1.member,t2.bytes/1024/1024 from v$logfile t1,v$log t2 where t1.group#=t2.group# order by 1,2;

DBCA命令行搭建Oracle ADG的流程

--需要注意:
--1.stanby log日志大小至少要和redo log日志一样大小,不能小于
--2.stanby log数量: standby logfile=(1+logfile组数)=(1+2)=3组,每个thread需要加3组standby logfile.
--3.thread要与redo log保持一致,如果是rac,需要增加多个thread对应的standby log

ALTER DATABASE ADD STANDBY LOGFILE thread 1 
group 5 ('+DATA') SIZE 120M,
group 6 ('+DATA') SIZE 120M,
group 7 ('+DATA') SIZE 120M;

ALTER DATABASE ADD STANDBY LOGFILE thread 2
group 8 ('+DATA') SIZE 120M,
group 9 ('+DATA') SIZE 120M,
group 10 ('+DATA') SIZE 120M;

DBCA命令行搭建Oracle ADG的流程

select t2.thread#,t1.group#,t1.member,t2.bytes/1024/1024 from v$logfile t1,v$standby_log t2 where t1.group#=t2.group# order by 1,2;

DBCA命令行搭建Oracle ADG的流程

三、DBCA创建物理备库

oracle用户执行:

dbca -silent -createDuplicateDB \
-gdbName cdb19c \
-sid cdb19c \
-sysPassword oracle \
-primaryDBConnectionString 10.211.55.105:1521/cdb19c \
-nodelist dbca_stby \
-databaseConfigType SINGLE \
-createAsStandby -dbUniqueName cdb19c_stby \
-datafileDestination '/oradata'

DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程

DBCA物理DG创建成功。

四、配置主库+备库DG参数

--主库设置DG参数
ALTER SYSTEM SET LOG_ARCHIVE_CONFIG='DG_CONFIG=(CDB19C,CDB19C_STBY)' sid='*';
ALTER SYSTEM SET LOG_ARCHIVE_DEST_1='LOCATION=+DATA VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=CDB19C' sid='*';
ALTER SYSTEM SET LOG_ARCHIVE_DEST_2='SERVICE=cdb19c_stby ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=CDB19C_STBY' sid='*';
ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=ENABLE sid='*';
ALTER SYSTEM SET LOG_ARCHIVE_MAX_PROCESSES=4 sid='*';
ALTER SYSTEM SET FAL_SERVER=CDB19C_STBY sid='*';
ALTER SYSTEM SET FAL_CLIENT=CDB19C sid='*';
ALTER SYSTEM SET DB_FILE_NAME_CONVERT='+DATA','/oradata/CDB19C_STBY' SCOPE=SPFILE sid='*';
ALTER SYSTEM SET LOG_FILE_NAME_CONVERT='+DATA','/oradata/CDB19C_STBY' SCOPE=SPFILE sid='*';
ALTER SYSTEM SET STANDBY_FILE_MANAGEMENT=AUTO sid='*';

注意:RAC修改参数需要加上 sid='*',修改多个实例。

--备库设置DG参数
ALTER SYSTEM SET LOG_ARCHIVE_CONFIG='DG_CONFIG=(CDB19C_STBY,CDB19C)';
ALTER SYSTEM SET LOG_ARCHIVE_DEST_1='LOCATION=/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=CDB19C_STBY';
ALTER SYSTEM SET LOG_ARCHIVE_DEST_2='SERVICE=CDB19C ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=CDB19C';
ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=ENABLE;
ALTER SYSTEM SET LOG_ARCHIVE_MAX_PROCESSES=4;
ALTER SYSTEM SET FAL_SERVER=CDB19C;
ALTER SYSTEM SET FAL_CLIENT=CDB19C_STBY;
ALTER SYSTEM SET DB_FILE_NAME_CONVERT='/oradata/CDB19C_STBY','+DATA' SCOPE=SPFILE;
ALTER SYSTEM SET LOG_FILE_NAME_CONVERT='/oradata/CDB19C_STBY','+DATA' SCOPE=SPFILE;
ALTER SYSTEM SET STANDBY_FILE_MANAGEMENT=AUTO;

查看OMF参数配置:

show parameter db_create_file_dest

DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程

注意:如果同时设置OMG和DB_FILE_NAME_CONVERT参数,则优先OMF参数。

五、开启日志应用

##备库执行
alter database recover managed standby database using current logfile disconnect from session;

##主库执行
alter system set log_archive_dest_state_2=enable sid='*';

DBCA命令行搭建Oracle ADG的流程
DBCA命令行搭建Oracle ADG的流程

六、测试同步

主库创建测试数据:

alter session set container=orcl;

DBCA命令行搭建Oracle ADG的流程

sqlplus lucifer/lucifer@orcl

DBCA命令行搭建Oracle ADG的流程

备库查看是否同步:

DBCA命令行搭建Oracle ADG的流程

至此,ADG已搭建完毕。感谢食用~

参考文章:

官方文档12c:Using DBCA to Create a Data Guard Standby 12C

官方文档19c:Using DBCA to Create a Data Guard Standby 19C

官方文档21c:Using DBCA to Create a Data Guard Standby 21C

MOS文档:Creating a Physical Standby database using DBCA duplicate (Doc ID 2283697.1)

以上就是DBCA搭建Oracle ADG的详细内容,更多关于DBCA搭建Oracle ADG的资料请关注三水点靠木其它相关文章!

Oracle 相关文章推荐
ORACLE数据库对long类型字段进行模糊匹配的解决思路
Apr 07 Oracle
Oracle 数据仓库ETL技术之多表插入语句的示例详解
Apr 12 Oracle
oracle表分区的概念及操作
Apr 24 Oracle
Oracle11g R2 安装教程完整版
Jun 04 Oracle
Oracle表空间与权限的深入讲解
Nov 17 Oracle
详解Oracle数据库中自带的所有表结构(sql代码)
Nov 20 Oracle
使用Oracle命令进行数据库备份与还原
Dec 06 Oracle
oracle重置序列从0开始递增1
Feb 28 Oracle
Oracle 多表查询基本语法实例
Apr 18 Oracle
oracle数据库去除重复数据
May 20 Oracle
Oracle锁表解决方法的详细记录
Jun 05 Oracle
Oracle删除归档日志及添加定时任务
Jun 28 Oracle
ORACLE数据库应用开发的三十个注意事项
Jun 07 #Oracle
Oracle创建只读账号的详细步骤
Oracle11g R2 安装教程完整版
Oracle11g r2 卸载干净重装的详细教程(亲测有效已重装过)
使用Navicat Premium工具将oracle数据库迁移到MySQL
Oracle更换为MySQL遇到的问题及解决
May 21 #Oracle
oracle覆盖导入dmp文件的2种方法
You might like
我的论坛源代码(六)
2006/10/09 PHP
php封装好的人民币数值转中文大写类
2015/12/20 PHP
PHP标准类(stdclass)用法示例
2016/09/28 PHP
javascript 事件查询综合 推荐收藏
2010/03/10 Javascript
当鼠标移动到图片上时跟随鼠标显示放大的图片效果
2013/06/06 Javascript
JavaScript常用全局属性与方法记录积累
2013/07/03 Javascript
浅谈jQuery中的checkbox问题
2016/08/10 Javascript
js原生跨域_用script标签的简单实现
2016/09/24 Javascript
javascript设计模式之策略模式学习笔记
2017/02/15 Javascript
jQuery Validate 相关参数及常用的自定义验证规则
2017/03/06 Javascript
JavaScript实现反转字符串的方法详解
2017/04/27 Javascript
浅谈用Webpack路径压缩图片上传尺寸获取的问题
2018/02/22 Javascript
js获取html页面代码中图片地址的实现代码
2018/03/05 Javascript
layer弹出子iframe层父子页面传值的实现方法
2018/11/22 Javascript
使用Easyui实现查询条件的后端传递并自动刷新表格的两种方法
2019/09/09 Javascript
如何在Python中编写并发程序
2016/02/27 Python
Python 多线程的实例详解
2017/09/07 Python
python的文件操作方法汇总
2017/11/10 Python
解决python "No module named pip" 的问题
2018/10/13 Python
Python中py文件转换成exe可执行文件的方法
2019/06/14 Python
Django中在xadmin中集成DjangoUeditor过程详解
2019/07/24 Python
python分布式编程实现过程解析
2019/11/08 Python
如何实现更换Jupyter Notebook内核Python版本
2020/05/18 Python
Python通过zookeeper实现分布式服务代码解析
2020/07/22 Python
python requests库的使用
2021/01/06 Python
matplotlib绘制正余弦曲线图的实现
2021/02/22 Python
印度第一网上礼品店:IGP.com
2020/02/06 全球购物
俄罗斯马克西多姆家居用品网上商店:Максидом
2020/02/06 全球购物
Crabtree & Evelyn欧盟:豪华洗浴、身体和护发
2021/03/09 全球购物
税务干部群众路线教育实践活动对照检查材料
2014/09/20 职场文书
2014年测量员工作总结
2014/12/12 职场文书
无保留意见审计报告
2015/06/05 职场文书
大学生奶茶店创业计划书
2019/06/25 职场文书
如何用JavaScipt测网速
2021/05/09 Javascript
SQL中的三种去重方法小结
2021/11/01 SQL Server
聊聊Python String型列表求最值的问题
2022/01/18 Python