第141期 DG PDB - Oracle DB 23c(20240129)

yhw1809發表於2024-01-29

第141期 DG PDB - Oracle DB 23c(20240129)

作者:胖頭魚的魚缸(尹海文)
Oracle ACE Associate: Database(Oracle與MySQL)
網思科技 DBA總監
10年資料庫行業經驗,現主要從事資料庫服務工作
擁有OCM 11g/12c/19c、MySQL 8.0 OCP、Exadata、CDP等認證
墨天輪MVP、認證技術專家,ITPUB認證專家,OCM講師
圈內擁有“總監”、“保安”、“國產資料庫最大敵人”等稱號,非著 名社恐(社交恐怖分子)
公眾號:胖頭魚的魚缸;CSDN:胖頭魚的魚缸(尹海文);墨天輪:胖頭魚的魚缸;ITPUB:yhw1809。
除授權轉載並標明出處外,均為“非法”抄襲。

首先,這應該是我一月份最後一片文章了(不保證),本期迴歸一下技術,重新轉頭把去年Oracle 23c系列文章中高可用這部分的坑給填了,深入捯飭一下DG PDB。

1 概念

從Oracle DB 23c開始,引入了DG PDB,即在原來CDB級別DG的基礎上,增加了PDB級別的DG,這種配置下CDB徹底淪為PDB的底座,PDB可以在任意CDB之間構建DG架構而不用考慮CDB的角色問題;相較於21c的功能,現在PDB備庫可以為只讀狀態了。
DG PDB的好處可以充分利用主備端的硬體資源,讓每個CDB都能承載生產PDB和災備PDB。

2 環境說明

這裡選擇了最新版本的Oracle Linux9.3作為作業系統,倆CDB均已開啟歸檔模式:
本次操作會根據實際情況進行,其中pdbprod1將在對端做DG PDB。

3 操作

3.1 資料庫配置

倆CDB均執行:

alter system set dg_broker_start=true;alter system set standby_file_management=auto;alter database flashback on;
prodcdb:alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=prodcdb' scope=both;
proddg:alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=proddg' scope=both;

倆CDB需要使用同樣的密碼檔案。

3.2 配置tnsname

/u01/app/oracle/product/23.0.0/dbhome_1/network/admin/tnsnames.ora

PRODCDB =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.10.10.101)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = prodcdb)
    )
  )
PRODDG =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.10.10.201)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = proddg)
    )
  )

image.png

3.3 配置強制日誌

alter database force logging;

3.4 DG配置

image.png

dgmgrl sys/oracle@prodcdb
dgmgrl>CREATE CONFIGURATION 'dgconf_1' AS PRIMARY DATABASE IS 'prodcdb' CONNECT IDENTIFIER IS prodcdb;
dgmgrl sys/oracle@proddg
dgmgrl>CREATE CONFIGURATION 'dgconf_2' AS PRIMARY DATABASE IS 'proddg' CONNECT IDENTIFIER IS proddg;

image.png
image.png

3.5 DG配置建立聯絡

dgmgrl sys/oracle@prodcdb
dgmgrl>
ADD CONFIGURATION 'dgconf_2' CONNECT IDENTIFIER IS proddg;show configuration;
dgmgrl sys/oracle@proddg
dgmgrl>show configuration;

image.png
image.png

3.6 啟用所有DG配置

dgmgrl sys/oracle@prodcdb
dgmgrl>
enable configuration all;show configuration;
dgmgrl sys/oracle@proddg
dgmgrl>show configuration;

image.png
image.png

3.7 啟用DG PDB

dgmgrl sys/oracle@prodcdb
dgmgrl>
EDIT CONFIGURATION PREPARE DGPDB;

image.png

3.8 建立源PDB的DG配置

dgmgrl sys/oracle@proddg
dgmgrl>
add pluggable database pdbdg1 at proddg source is pdbprod1 at prodcdb PDBFileNameConvert is "'/u01/app/oracle/oradata/PRODCDB','/u01/app/oracle/oradata/PRODDG'";

image.png

3.9 複製pdbprod1檔案至proddg

prodcdb:alter session set container=pdbprod1;alter database begin backup;
scp -r /u01/app/oracle/oradata/PRODCDB/100D0E78F6B3C90AE063650A0A0ACA90/ db23cdg:/u01/app/oracle/oradata/PRODDG/

image.png

prodcdb:alter session set container=pdbprod1;alter database end backup;

這裡同樣可以使用rman duplicate pluggable database來複制檔案,這裡不做演示。

3.10 目標PDB新增standby log

alter session set container=pdbdg1;alter database add standby logfile size 200m;alter database add standby logfile size 200m;alter database add standby logfile size 200m;alter database add standby logfile size 200m;

3.11 驗證並啟動DG PDB

dgmgrl sys/oracle@proddg
dgmgrl>
VALIDATE PLUGGABLE DATABASE pdbdg1 at proddg;

image.png

dgmgrl sys/oracle@proddg
dgmgrl>
edit PLUGGABLE DATABASE pdbdg1 at proddg set state='APPLY-ON';show configuration;show pluggable database pdbdg1 at proddg;show pluggable database pdbprod1 at prodcdb;

image.png

3.12 切換PDB角色

dgmgrl sys/oracle@proddg
dgmgrl>
VALIDATE PLUGGABLE DATABASE pdbdg1 at proddg;
switchover to pluggable database pdbdg1 at proddg;

image.png
image.png
image.png
image.png
這時候新的備庫會出現異常,因為沒有新增standby log,需要處理。

3.13 源庫PDB新增standby log

dgmgrl sys/oracle@proddg
dgmgrl>
edit PLUGGABLE DATABASE pdbprod1 at prodcdb set state='APPLY-OFF';alter session set container=pdbprod1;alter database add standby logfile size 200m;alter database add standby logfile size 200m;alter database add standby logfile size 200m;alter database add standby logfile size 200m;
dgmgrl sys/oracle@proddg
dgmgrl>
edit PLUGGABLE DATABASE pdbprod1 at prodcdb set state='APPLY-ON';show pluggable database pdbprod1 at prodcdb;

image.png

3.14 開啟備庫查詢

alter session set container=pdbprod1;alter pluggable database open;
dgmgrl>show pluggable database pdbprod1 at prodcdb;

image.png
image.png

3.15 回切測試

dgmgrl>
switchover to pluggable database pdbprod1 at prodcdb;show pluggable database pdbprod1 at prodcdb;show pluggable database pdbdg1 at proddg;show configuration;

image.png
至此DG PDB搭建完成。

總結

使用DG PDB初始化搭建還是比較繁瑣的,但是不需要全量CDB級別同步資料,還是比較方便,切換也很方便。
老規矩,知道寫了些啥。
參考文件:Scenarios for Using DGMGRL with a DG PDB Configuration (23c)(ttps://docs.oracle.com/en/database/oracle/oracle-database/23/dgbkr/scenarios-using-dgmgrl-dg-pdb-configuration-23c.html)


來自 “ ITPUB部落格 ” ,連結:https://blog.itpub.net/31466763/viewspace-3005623/,如需轉載,請註明出處,否則將追究法律責任。

相關文章