第141期 DG PDB - Oracle DB 23c(20240129)
第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) ) )
3.3 配置強制日誌
alter database force logging;
3.4 DG配置
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;
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;
3.6 啟用所有DG配置
dgmgrl sys/oracle@prodcdb dgmgrl> enable configuration all;show configuration; dgmgrl sys/oracle@proddg dgmgrl>show configuration;
3.7 啟用DG PDB
dgmgrl sys/oracle@prodcdb dgmgrl> EDIT CONFIGURATION PREPARE DGPDB;
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'";
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/
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;
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;
3.12 切換PDB角色
dgmgrl sys/oracle@proddg dgmgrl> VALIDATE PLUGGABLE DATABASE pdbdg1 at proddg; switchover to pluggable database pdbdg1 at proddg;
這時候新的備庫會出現異常,因為沒有新增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;
3.14 開啟備庫查詢
alter session set container=pdbprod1;alter pluggable database open; dgmgrl>show pluggable database pdbprod1 at prodcdb;
3.15 回切測試
dgmgrl> switchover to pluggable database pdbprod1 at prodcdb;show pluggable database pdbprod1 at prodcdb;show pluggable database pdbdg1 at proddg;show configuration;
至此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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【PDB】 為Oracle pdb新增服務(pdb add service)Oracle
- Oracle 建立PDB-Plugging In an Unplugged PDBOracle
- Oracle 23c安裝建議Oracle
- 【PDB】pdb閃回,Oracle還原點Oracle
- 【PDB】Oracle跨PDB檢視查詢Oracle
- 【PDB】Oracle PDB資源管理參考Oracle
- 【PDB】Oracle pdb維護常用sql命令OracleSQL
- Oracle:DG 的 switchoverOracle
- oracle dg報錯Oracle
- 【PDB】Oracle 建立pdb說明(create pluggable database)OracleDatabase
- Oracle 12.2 新特性: Online PDB relocate (PDB hot move)Oracle
- Oracle:PDB 引數管理Oracle
- Oracle RAC+DG搭建Oracle
- Oracle DG 日常點檢Oracle
- Oracle DG管理Broker配置Oracle
- Oracle 建立PDB-from ScratchOracle
- Oracle 建立PDB-本地克隆Oracle
- oracle19c連pdbOracle
- 【RECO_ORACLE】Oracle閃回PDB的方法Oracle
- 【ASK_ORACLE】Oracle如何重新命名PDBOracle
- 【DG】Oracle之級聯DG--(cascade dg) --(一主一備一級聯)Oracle
- ORACLE DG之備庫角色Oracle
- Oracle DG運維常用SQLOracle運維SQL
- oracle dg切換操作示例Oracle
- ORACLE 11.2.0.4 DG(Broker) for linux 部署OracleLinux
- Oracle DG Standby Database型別OracleDatabase型別
- Oracle DG建立Physical Standby DatabaseOracleDatabase
- Oracle DG建立Logical Standby DatabaseOracleDatabase
- 資料庫管理-第152期 Oracle Vector DB & AI-04(20240220)資料庫OracleAI
- 資料庫管理-第14期 Oracle Vector DB & AI-01(20240210)資料庫OracleAI
- 資料庫管理-第157期 Oracle Vector DB & AI-08(20240301)資料庫OracleAI
- 【DG】Oracle 19c使用dbca來搭建物理DGOracle
- Oracle 23C Free下載安裝及新特性Oracle
- Oracle 12.2新特性: PDB級閃回資料庫(Flashback PDB)Oracle資料庫
- 【ASK_ORACLE】Oracle Data Guard(一)DG架構Oracle架構
- Oracle 建立PDB-遠端克隆Oracle
- oracle 19c pdb遷移Oracle
- 【CDB】Oracle CDB/PDB常用管理命令Oracle