Amazon Web Services has been gaining popularity in the last few years since cloud computing has been in the spotlight. Slowly the Traditional Enterprises are making the journey to the cloud. Oracle is considered one of the most mission critical application in the Enterprise. Moving Oracle Database to cloud can bring its own benefits both from an operational and financial perspective.
In this exercise we will move an on-premise Oracle DB schema to an AWS RDS Instance running Oracle 12cR1
Pre-requisites :
1. You already have a source Oracle database installed
2. You know how to provision an AWS RDS Oracle Instance
3. You have access to both instances
4. You have basic understanding of AWS S3 and AWS console
5. You have the latest version of SQL Developer installed on your machine
Source DB:
Oracle 12cR1 (12.1.0.2) running on CentOS 7.1
Destination DB:
Oracle 12cR1 running on AWS RDS Instance
High Level Steps to Migrate:
1. Create the destination Oracle 12CR1 instance on AWS. It is one of the easiest things to provision an Oracle DB on AWS RDS
2. Connect to Both Source(on-Prem) and Destination(AWS) Database from SQL Developer
3. Go to Tools > Database Copy and Select Source and Destination Databases
I prefer to do Tablespace Copy since most of the Apps i work reside in a single tablespace. But this depends on your choice. You can either chose Objects, Schemas or even entire Tablespaces to be copied across.
IMPORTANT : Make sure you have created the source schema in destination database before proceeding to next step else you will get an error “User does not exist”
In Destination AWS RDS run below commands
SQL> create user <source-schema-name> identified by <password123>;
SQL> grant dba to <source-schema-name>;
4. Start the Database Copy
5. Check from Performance Insights Console to Check whats happening in the background
6. Query the Destination Database to See if the Objects are valid and have arrived
SQL> select * from user_tables;
SQL> select * from dba_objects where status=’INVALID’;