暂无图片
暂无图片
2
暂无图片
暂无图片
暂无图片

数据库管理-第358期 23ai:DG PDB(20250818)

原创 胖头鱼的鱼缸 2025-08-17
443

数据库管理358期 2025-08-18

数据库管理-第358期 23ai:DG PDB(20250818)

作者:胖头鱼的鱼缸(尹海文) Oracle ACE Pro: Database PostgreSQL ACE Partner 10年数据库行业经验 拥有OCM 11g/12c/19c、MySQL 8.0 OCP、Exadata、CDP等认证 墨天轮MVP,ITPUB认证专家 圈内拥有“总监”称号,非著名社恐(社交恐怖分子) 公众号:胖头鱼的鱼缸 CSDN:胖头鱼的鱼缸(尹海文) 墨天轮:胖头鱼的鱼缸 ITPUB:yhw1809 IFClub:胖头鱼的鱼缸 除授权转载并标明出处外,均为“非法”抄袭

胖头鱼的鱼缸.png
《数据库管理-第141期 DG PDB - Oracle DB 23c(20240129)》中,在Oracle 23c(内测版23.4)上部署过一次DG PDB,趁着内测版本更新到了23.9,且相较于之前官方文档已经完善,因此也在23ai上也再次部署一下DG PDB。

1 环境

image.png
DBCA建库过程中已按照默认方式完成以下配置:

  • 创建空CDB(无PDB)
  • 开启OMF
  • 开启指定FRA
  • 开启归档日志

后续在dbaas1中创建对应PDB。

2 配置DG PDB

2.1 配置tnsnames

vim /u01/app/oracle/product/23.0.0/dbhome_1/network/admin/tnsnames.ora DBAAS1 = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.10.10.151)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = dbaas1) ) ) DBAAS2 = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.10.10.152)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = dbaas2) ) )

2.2 复制密码文件

两个CDB需要使用相同的密码文件,在oracle239-01节点执行:

scp /u01/app/oracle/product/23.0.0/dbhome_1/dbs/orapwdbaas1 oracle239-02:/u01/app/oracle/product/23.0.0/dbhome_1/dbs/orapwdbaas2

2.3 数据库配置

两个CDB均需要执行:

alter system set dg_broker_start=true; alter system set standby_file_management=auto; alter database flashback on; alter database force logging;

不同CDB执行:

dbaas1: alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=dbaas1' scope=both; dbaas2: alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=dbaas2' scope=both;

image.png
image.png

2.4 创建DG配置

dgmgrl sys@dbaas1
DGMGRL> CREATE CONFIGURATION 'dgconf_1' AS PRIMARY DATABASE IS 'dbaas1' CONNECT IDENTIFIER IS dbaas1;

image.png

dgmgrl sys@dbaas2
DGMGRL> CREATE CONFIGURATION 'dgconf_2' AS PRIMARY DATABASE IS 'dbaas2' CONNECT IDENTIFIER IS dbaas2;

image.png

2.5 添加(关联)DG配置

dgmgrl sys@dbaas1
DGMGRL> ADD CONFIGURATION 'dgconf_2' CONNECT IDENTIFIER IS dbaas2;

image.png

2.6 启用DG配置并检查

DGMGRL> ENABLE CONFIGURATION ALL;

image.png
image.png

2.7 启用DG PDB

DGMGRL> EDIT CONFIGURATION PREPARE DGPDB;

image.png

2.8 创建源PDB的DG配置

DGMGRL> ADD PLUGGABLE DATABASE 'proddg' AT dbaas2 SOURCE is 'proddb' AT dbaas1;

image.png

2.8 复制数据文件

检查dbaas1中proddg的文件编号:

select file# from v$datafile;

image.png

rman target sys@dbaas1 auxiliary sys@dbaas2
run { allocate channel ch1 type disk; backup as copy reuse datafile 12,13,14 auxiliary format NEW; }

image.png
这里需要明确恢复文件的路径与文件名。

2.9 修改proddg数据文件路径与文件名

检查数据文件:

alter session set container=proddg; select name from v$datafile;

image.png
修改数据文件至正确路径与文件名:

alter database rename file '/u01/app/oracle/oradata/DBAAS1/3C8E6114F10BDF09E063970A0A0AA6F6/datafile/o1_mf_system_nb3dy189_.dbf' to '/u01/app/oracle/oradata/DBAAS2/3C8E6114F10BDF09E063970A0A0AA6F6/datafile/o1_mf_system_0a0te910_.dbf'; alter database rename file '/u01/app/oracle/oradata/DBAAS1/3C8E6114F10BDF09E063970A0A0AA6F6/datafile/o1_mf_sysaux_nb3dy18j_.dbf' to '/u01/app/oracle/oradata/DBAAS2/3C8E6114F10BDF09E063970A0A0AA6F6/datafile/o1_mf_sysaux_09pse90p_.dbf'; alter database rename file '/u01/app/oracle/oradata/DBAAS1/3C8E6114F10BDF09E063970A0A0AA6F6/datafile/o1_mf_undotbs1_nb3dy18j_.dbf' to '/u01/app/oracle/oradata/DBAAS2/3C8E6114F10BDF09E063970A0A0AA6F6/datafile/o1_mf_undotbs1_0b1te911_.dbf';

image.png

2.10 proddg添加standby logfile

alter session set container=proddg; ALTER DATABASE ADD STANDBY LOGFILE thread 1 group 4 size 200M, group 5 size 200M, group 6 size 200M, group 7 size 200M;

image.png

2.11 验证proddg

DGMGRL> VALIDATE PLUGGABLE DATABASE proddg AT dbaas2;

image.png

2.12 启动日志同步

DGMGRL> EDIT PLUGGABLE DATABASE proddg AT dbaas2 SET STATE='APPLY-ON';

image.png
在dbaas1中执行,可追平日志传输:

ALTER SYSTEM ARCHIVE LOG CURRENT; ALTER SYSTEM ARCHIVE LOG CURRENT;

image.png

2.13 开启proddg

alter pluggable database proddg open;

image.png
image.png

2.14 同步测试

proddb执行:

create tablespace users datafile size 50m; create table test (id number,name varchar2(20)) tablespace users; insert into test values(1,'sky'); commit;

image.png
proddg检查:
image.png

3 DG PDB切换

DGMGRL> SWITCHOVER TO PLUGGABLE DATABASE proddg AT dbaas2;

image.png
因为PRODDB中未添加standby logfile,无法正常同步,所以需要添加standby logfile:

DGMGRL> EDIT PLUGGABLE DATABASE proddb AT dbaas1 SET STATE='APPLY-OFF';
alter session set container=proddb; ALTER DATABASE ADD STANDBY LOGFILE thread 1 group 4 size 200M, group 5 size 200M, group 6 size 200M, group 7 size 200M;

image.png

DGMGRL> EDIT PLUGGABLE DATABASE proddb AT dbaas1 SET STATE='APPLY-ON';

dbaas2执行:

ALTER SYSTEM ARCHIVE LOG CURRENT; ALTER SYSTEM ARCHIVE LOG CURRENT;

同步恢复正常:
image.png

4 Failover

DGMGRL> FAILOVER TO PLUGGABLE DATABASE proddb AT dbaas1;

image.png
重新开启同步即可恢复proddg:

DGMGRL> reinstate pluggable database proddg at dbaas2; DGMGRL> EDIT PLUGGABLE DATABASE proddg AT dbaas2 SET STATE='APPLY-ON';

image.png

5 监控DG PDB

5.1 监控configuration

DGMGRL> show configuration
DGMGRL> show configuration verbose dgconf_1
DGMGRL> show configuration verbose dgconf_2

image.png
image.png
image.png

5.2 监控CDB

DGMGRL> show database dbaas1 DGMGRL> show database verbose dbaas2

image.png
image.png

5.3 监控PDB

DGMGRL> show pluggable database proddb at dbaas1; DGMGRL> show pluggable database proddg at dbaas2; DGMGRL> show all pluggable database at dbaas1;

image.png

5.4 验证DG PDB

DGMGRL> validate pluggable database proddb at dbaas1; DGMGRL> validate pluggable database proddg at dbaas2; DGMGRL> validate pluggable database pdb1 at dbaas1;

image.png

6 删除DG PDB

这里仅展示命令,不做演示。
dbaas1:

dgmgrl sys@dbaas1
DGMGRL> REMOVE PLUGGABLE DATABASE proddg AT dbaas2 REMOVE DATAFILES; DGMGRL> REMOVE CONFIGURATION dgconf_2; DGMGRL> REMOVE CONFIGURATION;

dbaas2:

dgmgrl sys@dbaas1
DGMGRL> REMOVE CONFIGURATION;

总结

本期在Oracle 23ai最新内测版23.9上进行了完整的DG PDB展示。
老规矩,知道写了些啥

最后修改时间:2025-08-18 10:14:03
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论