はじめに
Autonomous DatabaseではData Transformsというデータ変換ツールが付属しています。Data Transformsを使って東京リージョンのAutonomous DatabaseとBase Database間でデータ変換をするデータ・フローを作成したのですが、同じものを別のリージョンに作りたいとしたとき、せっかく作成したData Transformsのフローは作成しなおしになるのでしょうか。エクスポート、インポートが可能ではありますが、全部まるっとできないかということで東京リージョンからシドニーリージョンにクローンを試してみました。
前提条件
- Autonomous Databaseはプライベート・エンドポイントを利用。ただし、インターネット経由で付属ツールのアクセスができるようパブリック・アクセスを許可済み
- Autonomous Database、Base Databaseは同じプライベート・サブネットを使用。プライベート・サブネットにアクセスできるコンピュート・インスタンスを同じVCNのパブリック・サブネットに作成済み
- 東京リージョンのVCNとシドニーリージョンのVCNのCIDRは重複しない。(東京リージョン:10.100.0.0/16 、シドニーリージョン:10.0.0.0/16)
東京リージョンで環境構築
元となる東京リージョンの環境を構築します。
Autonomous DatabaseとBase Databaseを作成する
同じVCNのプライベート・サブネットを選択して、Autonomous DatabaseとBase Databaseのインスタンスを作成します。
Base Databaseのプラガブル・データベースPDB1にTESTUSERというユーザーも作成しました。
Data Transformsでデータフローを作成
Data Transformsでデータ・フローを作成します。以下の手順で実施します。
-
プライベート・エンドポイントのAutonomous Databaseであるため、Data Transformsでプライべート・ネットワークを利用するための以下のSQLコマンドを実行する(反映まで2時間くらいかかることがあります)
ALTER DATABASE PROPERTY SET ROUTE_OUTBOUND_CONNECTIONS = 'PRIVATE_ENDPOINT';
-
Data Transformsを起動しADMINユーザーでログインする
-
Autonomous DatabaseとBase Databaseに対してConnectionを作成
Data TransformのAutonomous Database(ローカル)へのConnection(接続)はデフォルトで作成済みのものはクローン後編集できないという不具合が2024/3時点(次期リリースで修正される模様)であるため、別に作成します。こちらの記事を参照して、Autonomous DatabaseはADMINユーザーで、Base Database(pdb1)はSYSTEMユーザーで接続するよう設定します。名前はAutonomous Databaseがatp1、Base Databaseはpdb1にしました。
- プロジェクトとデータ・フローを作成
Autonomous DatabaseのSSBユーザーのCUSTOMER表を条件(C_NATION='JAPAN')でフィルタし、Base Database(pdb1)のTESTUSERユーザーに新しい表として作成するデータ・フローを作成しました。データ・フローの作成手順などData Transformsの使い方はチュートリアルをご確認ください。
作成したデータ・フローを実行して成功を確認しておきます。
シドニーリージョンで環境構築
クローン先となるシドニーリージョンの環境を構築します。Autonomous Databaseはクローンで作成するので、プライベート・サブネットを選択したBase Databaseだけ作成します。このDBシステムに対して東京のBase DatabaseのPDB1のリモート・クローンを後で行います。
リージョン間ネットワークの疎通設定
リモートVCNピアリングの設定
画面はシドニーの情報ですが、シドニーと東京の両方で設定が必要です。
コンソールのメニューからネットワーキング→顧客接続性→動的ルーティング・ゲートウェイを選択し、動的ルーティング・ゲートウェイの作成をクリックします。任意の名前を入力して動的ルーティング・ゲートウェイの作成ボタンをクリックします。
動的ルーティング・ゲートウェイが作成され使用可能になりました。
次にタブから、アタッチメントを選択し、VCNアタッチメントから仮想クラウド・ネットワーク・アタッチメントの作成をクリックします。
任意の名前、VCNを入力して作成します。
作成されました!
アタッチメントを選択し、リモート・ピアリング接続アタッチメントからリモート・ピアリング接続の作成をクリックします。
任意の名前を入力し、リモート・ピアリング接続の作成をクリックします
作成されました!
同様に東京リージョンでも、動的ルーティング・ゲートウェイ、仮想クラウド・ネットワーク・アタッチメント、リモート・ピアリング接続の作成を行います。
接続の確立
接続の確立をします。右上の接続の確立をクリックします。
東京リージョンのリモート・ピアリング接続のOCIDを張り付けて、接続の確立をクリックします。
接続が確立されました。
東京のリモート・ピアリング接続の情報を確認すると、こちらもピアリング済みであることが確認できます。
ルート・ルールとセキュリティ・リストの設定
次に両リージョンのVCN(プライベート・サブネット、パブリック・サブネット)のルート・ルール、セキュリティ・リストでお互いにアクセスできるよう必要な設定を行います。
以下はシドニーのプライベート・サブネットのルート・ルールです。
セキュリティ・リストのイングレス・ルール、エグレス・ルールにもルールを追加します。
以下では同じVCNのパブリック・サブネットからはすべてのプロトコルを許可し、東京リージョンからのアクセスは1521、22で制限しています。
接続の確認
東京リージョンのパブリック・サブネットに作成済みのコンピュートからOracle Clientを使ってシドニーのプライベート・エンドポイントに作成したBase DatabaseのCDBにアクセスしてみます。接続文字列はデータベース詳細にあるデータベース接続で確認します。
今回DNS名の解決設定は行っていないので、ホスト名をIPアドレスに変更して接続の確認を行いました。DNS名の解決設定をする場合はこちらの記事が参考になると思います。
[oracle@dev1 ~]$ sqlplus system/<パスワード>@10.0.1.49:1521/syddb19c_syddb19c.prisubnet.sydaravcn1.oraclevcn.com
SQL*Plus: Release 21.0.0.0.0 - Production on Thu Apr 17 01:47:56 2025
Version 21.9.0.0.0
Copyright (c) 1982, 2022, Oracle. All rights reserved.
Last Successful login time: Tue Jan 21 2025 09:44:42 +00:00
Connected to:
Oracle Database 19c EE High Perf Release 19.0.0.0.0 - Production
Version 19.26.0.0.0
SQL>
Base Databaseのリモート・クローン
Base DatabaseにはPDBのリモート・クローン機能が存在しますが、ドキュメントに同じAD上のみとあり、リージョン間だと利用できませんでした。そのため手動でリモート・クローンを実行します。
東京リージョンのPDBにデータベース・リンク用のユーザーを作成
リモート・クローンはターゲットのCDBでソースPDBへのデータベース・リンクを作成し、それを指定してPDBを作成します。
東京リージョンのCDBに共通ユーザーを作成するか、ソースのPDBにローカル・ユーザーを作成する必要がありますが、今回は後者でユーザーを作成しました。
-- 東京のBaseDBのPDB1にSYSユーザーで接続
sqlplus / as sysdba
SQL> ALTER SESSION SET container=pdb1;
SQL> CREATE USER remote_clone_user IDENTIFIED BY <パスワード>;
-- 必要な権限を付与(最小の例)
SQL> GRANT CREATE SESSION, CREATE PLUGGABLE DATABASE TO remote_clone_user;
シドニーリージョンのCDBでデータベース・リンクを作成
次にターゲットであるシドニーリージョンのCDBでソース・データベースである東京リージョンのCDBへのデータベース・リンクを作成します。
-- シドニーのBaseDBのCDBにSYSユーザーで接続し実行する
sqlplus sys/<パスワード>@10.0.1.49:1521/syddb19c_syddb19c.prisubnet.sydaravcn1.oraclevcn.com as sysdba
SQL> CREATE DATABASE LINK PDB1.PRIVATE1.VCN1.ORACLEVCN.COM
CONNECT TO REMOTE_CLONE_USER IDENTIFIED BY <パスワード> USING '(DESCRIPTION=(CONNECT_TIMEOUT=5)(TRANSPORT_CONNECT_TIMEOUT=3)(RETRY_COUNT=3)(ADDRESS_LIST=(LOAD_BALANCE=on)(ADDRESS=(PROTOCOL=TCP)(HOST=10.100.1.104)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=pdb1.private1.vcn1.oraclevcn.com)))'
-- データベース・リンクの確認
SQL> select * from user_users@pdb1.PRIVATE1.VCN1.ORACLEVCN.COM;
USERNAME USER_ID ACCOUNT_STATUS LOCK_DATE EXPIRY_DATE DEFAULT_TABLESPACE TEMPORARY_TABLESPACE LOCAL_TEMP_TABLESPACE CREATED INITIAL_RSRC_CONSUMER_GROUP EXTERNAL_NAME PROXY_ONLY_CONNECT COMMON ORACLE_MAINTAINED INHERITED DEFAULT_COLLATION IMPLICIT ALL_SHARD PASSWORD_CHANGE_DATE
----------------- ------- -------------- ------------ ------------------ ------------------ -------------------- --------------------- ------------------ --------------------------- ------------- ------------------ ------ ----------------- --------- ----------------- -------- --------- --------------------
REMOTE_CLONE_USER 112 OPEN Invalid Date 2025/6/16 11:34:55 USERS TEMP TEMP 2025/4/17 11:34:55 DEFAULT_CONSUMER_GROUP null N NO N NO USING_NLS_COMP NO NO 2025/4/17 11:34:55
1行が選択されました。
シドニーリージョンのCDBでPDBのクローンを実行
続けてクローンを実行します。
Base Databaseはデフォルトで暗号化されているので、ドキュメントの「統一モードで、暗号化データを含むPDBのリモート・クローニングを2つのCDB間で実行する」にある記載に従って、KEYSTORE IDENTIFIED BY句を指定します。
-- シドニーのBaseDBのCDBにSYSユーザーで接続して実行
SQL> create pluggable database CLONE_PDB1 from PDB1@pdb1.PRIVATE1.VCN1.ORACLEVCN.COM KEYSTORE IDENTIFIED BY <パスワード>;
Pluggable database CLONE_PDB1 created.
シドニーリージョンでクローンPDBをOPEN
作成したPDBの情報を確認し、OPENします。
SQL> select * from v$pdbs; -- CLONE_PDB1の情報があることを確認
CON_ID DBID CON_UID GUID NAME OPEN_MODE RESTRICTED OPEN_TIME CREATE_SCN TOTAL_SIZE BLOCK_SIZE RECOVERY_STATUS SNAPSHOT_PARENT_CON_ID APPLICATION_ROOT APPLICATION_PDB APPLICATION_SEED APPLICATION_ROOT_CON_ID APPLICATION_ROOT_CLONE PROXY_PDB LOCAL_UNDO UNDO_SCN UNDO_TIMESTAMP CREATION_TIME DIAGNOSTICS_SIZE PDB_COUNT AUDIT_FILES_SIZE MAX_SIZE MAX_DIAGNOSTICS_SIZE MAX_AUDIT_SIZE LAST_CHANGED_BY TEMPLATE TENANT_ID UPGRADE_LEVEL GUID_BASE64
------ ---------- ---------- ------------------------ ---------- ---------- ---------- ------------------------ ---------- ---------- ---------- --------------- ---------------------- ---------------- --------------- ---------------- ----------------------- ---------------------- --------- ---------- -------- -------------- ------------------ ---------------- --------- ---------------- -------- -------------------- -------------- --------------- -------- --------- ------------- ------------------------
2 2820305893 2820305893 LDUu1/xiGRfgYxkC9AqRBA== PDB$SEED READ ONLY NO 2025-04-17T01:32:44.203Z 2166472 1458569216 8192 ENABLED null NO NO NO null NO NO 1 280 Invalid Date 2025/1/21 9:41:36 0 0 0 0 0 0 COMMON USER NO null 1 LDUu1/xiGRfgYxkC9AqRBAA=
3 1592369208 1592369208 LDVb30pJHwfgYxkC9AqvKQ== PDB0 READ WRITE NO 2025-04-17T01:32:46.732Z 2413382 1474297856 8192 ENABLED null NO NO NO null NO NO 1 280 Invalid Date 2025/1/21 9:54:11 0 0 0 0 0 0 COMMON USER NO null 1 LDVb30pJHwfgYxkC9AqvKQA=
4 3775040101 3775040101 MvHI1HbI0ZLgYzEBAApkFQ== CLONE_PDB1 MOUNTED null 2025-04-17T03:15:21.582Z 3210508 9552789504 8192 ENABLED null NO NO NO null NO NO 1 280 Invalid Date 2025/4/17 12:13:23 0 0 0 0 0 0 COMMON USER NO null 1 MvHI1HbI0ZLgYzEBAApkFQA=
3行が選択されました。
SQL> alter pluggable database clone_pdb1 open;
Pluggable database CLONE_PDB1 altered.
手動で作成したのですぐにはコンソールに反映されません。ドキュメントによると、6時間という記載がありましたので、待って確認してみたところ、コンソールにも表示がされました!
Autonomous Databaseのクローン
東京リージョンのAutonomous Databaseをシドニーリージョンにクローンします。Autonomous Databaseはリージョン間のクローンもコンソールで可能です。その他のアクションからクローンの作成を選択します。
リージョンにはシドニー、VCN、サブネットはシドニーリージョンでBase Databaseを作成するときに指定した作成済みのVCN、プライベート・サブネットを選択してフル・クローンします。
クローンが作成されました。一般情報のソースのクローニングに東京リージョンのAutonomous Databaseの名前が確認できます。
Data Transformsにアクセスしフローを実行
クローンしたAutonomous DatabaseのData Transformsにアクセスし、ADMINユーザーでログインします。
Connectionsやデータ・フローやワーク・フローが存在することが確認できました。
しかし、Connectionの定義は東京リージョンのAutonomous Dataase、Base Databaseを指したままなので変更が必要です。atp1、pdb1のJDBC URLをシドニーリージョンのAutonomous Database、Base DatabaseのPDBの文字列に修正します。
修正後、データ・フローを実行すると、成功しました!
おわりに
東京リージョンで構築した環境をシドニーリージョンにクローンでもっていくことが無事できました。試している途中で確認したこともせっかくなので記載しておきます。
ついでにやってみたことやぶつかったこと
Base Databaseの接続を作成してSQLワークシートを利用する
接続を作成すると、コンソールからSQLワークシートが利用できます。コンピュートを用意する必要がなく便利かと思い、作成したDBシステムのデータベース詳細で接続を作成してみました。
接続の作成をクリックして
必要な項目を入力します。パスワード・シークレット、プライベート・エンドポイントは既存のものがない場合は作成できます。
作成したら作成済みの接続をクリックし、右上のSQLワークシートをクリックします。
SQLワークシートの例は以下のとおり。クライアントツールを準備しなくてもデータベースにアクセスできます。要塞があれば、SQLCLも利用できそうです。
なお、セキュリティ・リストのエグレスルールにプライベート・サブネットのCIDRがないとORA-12170でアクセスできませんでした。
Base Databaseのパッチレベルをあわせる
実は東京リージョンとシドニーリージョンのBase Databaseのパッチレベルが違っており(東京19.24、シドニー19.26 )クローンした後のOPENで警告が発生し、RestrictedモードでのOPENとなりました。
alter pluggable database clone_pdb1 open;
ORA-17110 位置 0,0
Execution completed with warning. https://docs.oracle.com/error-help/db/ora-17110/
select * from v$pdbs;
CON_ID DBID CON_UID GUID NAME OPEN_MODE RESTRICTED OPEN_TIME CREATE_SCN TOTAL_SIZE BLOCK_SIZE RECOVERY_STATUS SNAPSHOT_PARENT_CON_ID APPLICATION_ROOT APPLICATION_PDB APPLICATION_SEED APPLICATION_ROOT_CON_ID APPLICATION_ROOT_CLONE PROXY_PDB LOCAL_UNDO UNDO_SCN UNDO_TIMESTAMP CREATION_TIME DIAGNOSTICS_SIZE PDB_COUNT AUDIT_FILES_SIZE MAX_SIZE MAX_DIAGNOSTICS_SIZE MAX_AUDIT_SIZE LAST_CHANGED_BY TEMPLATE TENANT_ID UPGRADE_LEVEL GUID_BASE64
------ ---------- ---------- ------------------------ ---------- ---------- ---------- ------------------------ ---------- ---------- ---------- --------------- ---------------------- ---------------- --------------- ---------------- ----------------------- ---------------------- --------- ---------- -------- -------------- ------------------ ---------------- --------- ---------------- -------- -------------------- -------------- --------------- -------- --------- ------------- ------------------------
2 2820305893 2820305893 LDUu1/xiGRfgYxkC9AqRBA== PDB$SEED READ ONLY NO 2025-04-17T01:32:44.203Z 2166472 1458569216 8192 ENABLED null NO NO NO null NO NO 1 280 Invalid Date 2025/1/21 9:41:36 0 0 0 0 0 0 COMMON USER NO null 1 LDUu1/xiGRfgYxkC9AqRBAA=
3 1592369208 1592369208 LDVb30pJHwfgYxkC9AqvKQ== PDB0 READ WRITE NO 2025-04-17T01:32:46.732Z 2413382 1474297856 8192 ENABLED null NO NO NO null NO NO 1 280 Invalid Date 2025/1/21 9:54:11 0 0 0 0 0 0 COMMON USER NO null 1 LDVb30pJHwfgYxkC9AqvKQA=
4 3775040101 3775040101 MvHI1HbI0ZLgYzEBAApkFQ== CLONE_PDB1 READ WRITE YES 2025-04-17T03:17:43.518Z 3210508 9552789504 8192 ENABLED null NO NO NO null NO NO 1 280 Invalid Date 2025/4/17 12:13:23 0 0 0 0 0 0 COMMON USER NO null 1 MvHI1HbI0ZLgYzEBAApkFQA=
Elapsed: 00:00:00.020
3行が選択されました。
pdb_plug_in_violationsを参照したところ、TYPEがERRORでSTATUSがPENDINGになっているものがありました。(★もOPEN前はPendingでしたが、OPEN後はRESOLVEDになっていました。)
select * from pdb_plug_io_violations;
NAME CAUSE TYPE MESSAGE STATUS ACTION
---------- ------------------------ ------- ------------------------------------------------------------------------------------------------------------------------------------------------------------------- -------- -----------------------------------------------
CLONE_PDB1 Parameter WARNING CDB parameter pga_aggregate_limit mismatch: Previous 7424M Current 6912M RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 Parameter WARNING CDB parameter nls_language mismatch: Previous 'AMERICAN' Current 'JAPANESE' RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 Parameter WARNING CDB parameter wallet_root mismatch: Previous '/opt/oracle/dcs/commonstore/wallets/aradb19c_ps5_nrt' Current '/opt/oracle/dcs/commonstore/wallets/syddb19c_syddb19c' RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 Parameter WARNING CDB parameter pga_aggregate_target mismatch: Previous 3712M Current 3456M RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 SQL Patch ERROR '19.26.0.0.0 Release_Update 2501181248' is installed in the CDB but '19.24.0.0.0 Release_Update 2406272351' is installed in the PDB PENDING Call datapatch to install in the PDB or the CDB
CLONE_PDB1 SQL Patch ERROR Interim patch 37102264/25987410 (OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264)): Installed in the CDB but not in the PDB PENDING Call datapatch to install in the PDB or the CDB
CLONE_PDB1 SQL Patch ERROR Interim patch 36414915/25700138 (OJVM RELEASE UPDATE: 19.24.0.0.240716 (36414915)): Not installed in the CDB but installed in the PDB PENDING Call datapatch to install in the PDB or the CDB
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36538667 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB. ★
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36414915 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB. ★
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36587798 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB. ★
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36582781 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB. ★
PDB$SEED SQL Patch ERROR Interim patch 37102264/25987410 (OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264)): Installed in the CDB but not in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
PDB$SEED SQL Patch ERROR '19.26.0.0.0 Release_Update 2501181248' is installed in the CDB but no release updates are installed in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
PDB0 is encrypted tablespace? WARNING Tablespace SYSTEM is not encrypted. Oracle Cloud mandates all tablespaces should be encrypted. RESOLVED Encrypt the tablespace.
PDB0 is encrypted tablespace? WARNING Tablespace SYSAUX is not encrypted. Oracle Cloud mandates all tablespaces should be encrypted. RESOLVED Encrypt the tablespace.
PDB0 is encrypted tablespace? WARNING Tablespace USERS is not encrypted. Oracle Cloud mandates all tablespaces should be encrypted. RESOLVED Encrypt the tablespace.
Base Databaseのコンピュートにログインし、datapatchを実行します。Precheck後問題なさそうだったのでそのまま実行しました。
[oracle@syd19c OPatch]$ ./datapatch -verbose -prereq -pdbs clone_pdb1
[oracle@syd19c OPatch]$ ./datapatch -verbose -pdbs clone_pdb1
SQL Patching tool version 19.26.0.0.0 Production on Thu Apr 17 15:13:01 2025
Copyright (c) 2012, 2025, Oracle. All rights reserved.
Log file for this invocation: /u01/app/oracle/cfgtoollogs/sqlpatch/sqlpatch_39910_2025_04_17_15_13_01/sqlpatch_invocation.log
Connecting to database...OK
Gathering database info...done
Note: Datapatch will only apply or rollback SQL fixes for PDBs
that are in an open state, no patches will be applied to closed PDBs.
Please refer to Note: Datapatch: Database 12c Post Patch SQL Automation
(Doc ID 1585822.1)
Bootstrapping registry and package to current versions...done
Determining current state...done
Current state of interim SQL patches:
Interim patch 36414915 (OJVM RELEASE UPDATE: 19.24.0.0.240716 (36414915)):
Binary registry: Not installed
PDB CLONE_PDB1: Applied successfully on 16-JUL-24 04.51.55.681299 AM
Interim patch 37102264 (OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264)):
Binary registry: Installed
PDB CLONE_PDB1: Not installed
Current state of release update SQL patches:
Binary registry:
19.26.0.0.0 Release_Update 250118124854: Installed
PDB CLONE_PDB1:
Applied 19.24.0.0.0 Release_Update 240627235157 successfully on 16-JUL-24 04.56.35.205276 AM
Adding patches to installation queue and performing prereq checks...done
Installation queue:
For the following PDBs: CLONE_PDB1
The following interim patches will be rolled back:
36414915 (OJVM RELEASE UPDATE: 19.24.0.0.240716 (36414915))
Patch 37260974 (Database Release Update : 19.26.0.0.250121 (37260974)):
Apply from 19.24.0.0.0 Release_Update 240627235157 to 19.26.0.0.0 Release_Update 250118124854
The following interim patches will be applied:
37102264 (OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264))
Installing patches...
Patch installation complete. Total patches installed: 3
Validating logfiles...done
Patch 36414915 rollback (pdb CLONE_PDB1): SUCCESS
logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/36414915/25700138/36414915_rollback_SYDDB19C_CLONE_PDB1_2025Apr17_15_13_35.log (no errors)
Patch 37260974 apply (pdb CLONE_PDB1): SUCCESS
logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/37260974/26040769/37260974_apply_SYDDB19C_CLONE_PDB1_2025Apr17_15_13_49.log (no errors)
Patch 37102264 apply (pdb CLONE_PDB1): SUCCESS
logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/37102264/25987410/37102264_apply_SYDDB19C_CLONE_PDB1_2025Apr17_15_13_48.log (no errors)
Automatic recompilation incomplete; run utlrp.sql to revalidate.
PDBs: CLONE_PDB1
SQL Patching tool complete on Thu Apr 17 15:14:19 2025
完了したので、CLONE_PDB1を再起動します。
SQL> alter pluggable database clone_pdb1 close;
Pluggable database CLONE_PDB1 altered.
SQL> alter pluggable database clone_pdb1 open;
Pluggable database CLONE_PDB1 altered.
SQL> select name,cause,type,message,status,action from pdb_plug_in_violations order by name;
NAME CAUSE TYPE MESSAGE STATUS ACTION
---------- ------------------------ ------- ------------------------------------------------------------------------------------------------------------------------------------------------------------------- -------- -----------------------------------------------
CLONE_PDB1 Parameter WARNING CDB parameter pga_aggregate_limit mismatch: Previous 7424M Current 6912M RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 Parameter WARNING CDB parameter nls_language mismatch: Previous 'AMERICAN' Current 'JAPANESE' RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 Parameter WARNING CDB parameter wallet_root mismatch: Previous '/opt/oracle/dcs/commonstore/wallets/aradb19c_ps5_nrt' Current '/opt/oracle/dcs/commonstore/wallets/syddb19c_syddb19c' RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 Parameter WARNING CDB parameter pga_aggregate_target mismatch: Previous 3712M Current 3456M RESOLVED Please check the parameter in the current CDB
CLONE_PDB1 SQL Patch ERROR '19.26.0.0.0 Release_Update 2501181248' is installed in the CDB but '19.24.0.0.0 Release_Update 2406272351' is installed in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
CLONE_PDB1 SQL Patch ERROR Interim patch 37102264/25987410 (OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264)): Installed in the CDB but not in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
CLONE_PDB1 SQL Patch ERROR Interim patch 36414915/25700138 (OJVM RELEASE UPDATE: 19.24.0.0.240716 (36414915)): Not installed in the CDB but installed in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36538667 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB.
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36414915 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB.
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36587798 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB.
CLONE_PDB1 Oracle Opatch WARNING Oracle opatch mismatch: opatch 36582781 is missing in the CDB. RESOLVED Install the Oracle opatch in the CDB.
PDB$SEED SQL Patch ERROR Interim patch 37102264/25987410 (OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264)): Installed in the CDB but not in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
PDB$SEED SQL Patch ERROR '19.26.0.0.0 Release_Update 2501181248' is installed in the CDB but no release updates are installed in the PDB RESOLVED Call datapatch to install in the PDB or the CDB
PDB0 is encrypted tablespace? WARNING Tablespace SYSTEM is not encrypted. Oracle Cloud mandates all tablespaces should be encrypted. RESOLVED Encrypt the tablespace.
PDB0 is encrypted tablespace? WARNING Tablespace SYSAUX is not encrypted. Oracle Cloud mandates all tablespaces should be encrypted. RESOLVED Encrypt the tablespace.
PDB0 is encrypted tablespace? WARNING Tablespace USERS is not encrypted. Oracle Cloud mandates all tablespaces should be encrypted. RESOLVED Encrypt the tablespace.
16行が選択されました。
SQL> alter session set conatiner=clone_pdb1;
SQL> select PATCH_TYPE,ACTION, STATUS,DESCRIPTION, TARGET_VERSION, TARGET_BUILD_DESCRIPTION from DBA_REGISTRY_SQLPATCH;
PATCH_TYPE ACTION STATUS DESCRIPTION TARGET_VERSION TARGET_BUILD_DESCRIPTION
---------- -------- ------- ----------------------------------------------------- -------------- ------------------------
INTERIM APPLY SUCCESS OJVM RELEASE UPDATE: 19.24.0.0.240716 (36414915) 19.24.0.0.0 Release_Update
RU APPLY SUCCESS Database Release Update : 19.24.0.0.240716 (36582781) 19.24.0.0.0 Release_Update
INTERIM ROLLBACK SUCCESS OJVM RELEASE UPDATE: 19.24.0.0.240716 (36414915) 19.26.0.0.0 Release_Update
INTERIM APPLY SUCCESS OJVM RELEASE UPDATE: 19.26.0.0.250121 (37102264) 19.26.0.0.0 Release_Update
RU APPLY SUCCESS Database Release Update : 19.26.0.0.250121 (37260974) 19.26.0.0.0 Release_Update
Elapsed: 00:00:00.006
5行が選択されました。
どれもRESOLVEDになっています。DBA_REGISTRY_SQLPATCHの情報も19.26になっていました。後はINVALIDのオブジェクトを再コンパイルするutlrp.sqlを実行して完了しました。
[oracle@syd19c OPatch]$ sqlplus / as sysdba
SQL> alter session set container=clone_pdb1;
-- INVALIDのオブジェクトを確認
SQL> select count(*) from dba_objects where status='INVALID';
COUNT(*)
--------
652
1行が選択されました。
SQL> @$ORACLE_HOME/rdbms/admin/utlrp.sql
Session altered.
TIMESTAMP
--------------------------------------------------------------------------------
COMP_TIMESTAMP UTLRP_BGN 2025-04-17 15:23:22
DOC> The following PL/SQL block invokes UTL_RECOMP to recompile invalid
:
:
PL/SQL procedure successfully completed.
--実行後再確認
SQL> select count(*) from dba_objects where status='INVALID';
COUNT(*)
--------
0
Autonomous Databaseをクローンしたときにパブリック・アクセスをOnにしたのにクローン後ツール・アクセスのURLが表示されない
Autonomous Databaseのクローンは成功したのですが、パブリック・アクセスは有効にもかかわらず、ツールのパブリック・アクセスURLが表示されませんでした。
いったん、その他のアクションから、ネットワークの変更を選択し、パブリック・アクセスをOffに変更、その後改めてOnにしたところ、出力がされました。
クローン後のData Transformsの接続定義を変更したがエラーになる
クローンしてすぐのAutnomous Databaseでは、Data TransformsのConnectionsのJDBC_URLを正しい宛先に変更しても接続のテスト(Test Connection)で以下のエラーになりました。
Failed to connect to "atp1" : IO Error: The Network Adapter could not establish the connection.
Check whether your Autonomous Database is configured to use a Private Endpoint.
2時間くらい経った後接続できるようになりました。プライベート・ネットワークでの有効化がされるのに時間がかかるのかもしれません。