In case you missed the previous posts:
- Part 1 – Refreshable Clone PDBs
- Part 2 – Non-CDB 19c to 23ai PDB
- Part 3 – 19c PDB to 23ai
- Part 4 – Fallback options
- Part 5 – Target_pdb_copy_option
- Part 6 – Create a 23ai Database with Compatible set to 19c
- Part 7 – Downgrade
This post covers the migration of a 19c database from a non-CDB to a PDB in the multitenant architecture.
When planning an upgrade to 23ai, some customers prefer a two-step approach: first migrating to the multitenant architecture, then upgrading to 23ai.
First Step
Remember to always download the latest AutoUpgrade version from MOS.
There is also a new option: Download AutoUpgrade directly from oracle.com
Checking the environment
I have a 19c database home in my Exadata:
data:image/s3,"s3://crabby-images/6db2b/6db2b547a1b1c731462d55a7798e54d5976787fb" alt=""
There is 1 database created using this database homes a 19c NON-CDB:
data:image/s3,"s3://crabby-images/8a021/8a021225d77da610611cf86274afc7e6488c6e25" alt=""
data:image/s3,"s3://crabby-images/429f6/429f68277cc66a259a780622dfc803acb646ef7a" alt=""
You can check this blog post if you need to create a non-cdb 19c on ExaCS or ExaCC.
I created a new 19c CDB Database called DB19:
data:image/s3,"s3://crabby-images/0dc79/0dc79ad556262dbf90041208e1d4c05cdab5c913" alt=""
The 19c CDB database is still empty, but I can use a CDB with existing PDBs. I just need to ensure there are no naming conflicts with my non-CDB:
data:image/s3,"s3://crabby-images/e96f0/e96f0370597d8cb3c42b1e02b7bbec9a83b97c4e" alt=""
Let’s check the AutoUpgrade version:
java -jar autoupgrade.jar -version
data:image/s3,"s3://crabby-images/e9323/e932348865c80338af4dd67c85d641f017884892" alt=""
Let’s create an AutoUpgrade config file:
global.autoupg_log_dir=/u02/AutoUpgrade
global.keystore=/u02/keystore
upg1.source_home=/u02/app/oracle/product/19.0.0.0/dbhome_1
upg1.target_home=/u02/app/oracle/product/19.0.0.0/dbhome_1
upg1.sid=NCDB191
upg1.target_cdb=DB191
data:image/s3,"s3://crabby-images/c3bf3/c3bf395d677066357f63fac8c3a1a106999277a7" alt=""
Let’s load the TDE encryption password for both databases:
java -jar autoupgrade.jar -config NCDB191.cfg -load_password
data:image/s3,"s3://crabby-images/23d62/23d624126f01b7902ab60ae2037ed776b6681f1c" alt=""
Let’s run the Analyze mode:
java -jar autoupgrade.jar -config NCDB191.cfg -mode analyze
data:image/s3,"s3://crabby-images/be103/be103f6d95b9ed9f4dcc9f249c7686760f55d95e" alt=""
As you can see, for this test, no manual steps are needed:
data:image/s3,"s3://crabby-images/e1302/e1302573c3eef32aa01651bf04af095331b53e9b" alt=""
Let’s run the Deploy mode to start the migration:
java -jar autoupgrade.jar -config NCDB191.cfg -mode deploy
data:image/s3,"s3://crabby-images/1b8e9/1b8e9297ac37187d76e0e1d25c2e91b33898dff5" alt=""
There are a few ways to see the progress:
data:image/s3,"s3://crabby-images/73110/73110209ee4f2dfda558e2704c22834a7ec3ac92" alt=""
data:image/s3,"s3://crabby-images/33c1c/33c1c4d41d159e250389f8c96764602496557e81" alt=""
data:image/s3,"s3://crabby-images/21a1b/21a1b71fb0195856fc092f95c5bee7ec75684f87" alt=""
data:image/s3,"s3://crabby-images/8c0d6/8c0d6c00fc25f4a6558cbd7989bc91ebc02de711" alt=""
As you can see below, the conversion from 19c non-cdb to 19c pdb was a success:
data:image/s3,"s3://crabby-images/945a6/945a6447a6b49e680d0963d78851e43709e448f3" alt=""
We have now the NCDB19 plugged in and running on the 19c CDB:
data:image/s3,"s3://crabby-images/37212/3721203a92058bc8ec42b8fcb6a12494e69fa320" alt=""
Will the console recognize the new PDB?
And the answer is: Yes
It took a few minutes, but it’s there now:
data:image/s3,"s3://crabby-images/abce1/abce1b7814c35ad683cd50be409d88c7cd037bec" alt=""
Links to the Complete Blog Post Series on AutoUpgrade for ExaDB-D/ExaC@C: