Homogeneous database migration considerations
This section discusses key best practices for homogeneous migrations. When you migrate your database from Exadata on premises to Amazon RDS for Oracle or Oracle on Amazon EC2, consider the guidelines that are discussed in the following subsections.
Encryption
Data security is top priority at AWS. AWS has implemented rigorous contractual, technical, and organizational measures to protect customers' confidentiality, integrity, and availability. For databases, encryption is critical because it protects private information and sensitive data. Oracle on Amazon EC2 and Amazon RDS for Oracle support two encryption methods for data at rest:
- 
                    AWS Key Management Service (AWS KMS) to encrypt Amazon EBS volumes. 
- 
                    Oracle Advanced Security Option Transparent Data Encryption (TDE) to encrypt sensitive information that is stored in data files. Oracle TDE requires an Oracle license. 
Both options encrypt user data in the Oracle database and in all database backups. Encryption is also transparent to the DML statements issued from applications.
For data in transit, Oracle on Amazon EC2 and Amazon RDS for Oracle support Oracle Native Network Encryption (NNE). For more information about NNE support, see the Amazon RDS documentation.
Data partitioning
With Oracle Partitioning, a single logical object in the database, such as a table or an index, is divided into smaller physical database objects, which helps improve manageability, performance, and availability. Oracle Partitioning requires an Oracle license.
If you have large database workloads, consider partitioning your tables. Partition
                pruning enables the Oracle Database optimizer to analyze FROM and
                    WHERE clauses in SQL statements to eliminate unneeded partitions
                when building the partition access list. Oracle Database performs operations only on
                the partitions that are relevant to the SQL statement, which typically improves
                performance.
Partitioning also helps with availability. If a partition goes offline and a SQL statement doesn't need the offline partition in order to complete an operation, the SQL statement will succeed. However, if a data block is lost within an Oracle Database table that hasn't been partitioned, the entire table will be unavailable until the restore operation is complete.
Data compression
For data compression, Oracle offers both HCC and Advanced Compression. Advanced Compression improves performance and reduces storage costsby reducing the database storage footprint for relational data (tables), unstructured data (files), indexes, Data Guard redo data, network data, RMAN backups, and other types of data. Advanced Compression can also improve the performance of database infrastructure components, including memory and network bandwidth.
According to Oracle documentation
ILM strategy
Information Lifecycle Management (ILM) provides processes, policies, and components that help manage the information in a database based on its usage frequency. When you migrate from Exadata to Oracle on AWS, you should determine whether you can purge any data before or after migrating it to AWS. On AWS, you can apply rules to maintain data for a specific period of time only. You can implement Oracle Partitioning and Oracle Advanced Compression to set up data lifecycle policies. This can improve performance while maintaining only the data that is required to support your business.
For example, let's say you have a table that consumes multiple tebibytes of uncompressed data. You currently have 12 years of data, and you must keep data for 14 years. About 90 percent of all queries access data that is less than two years old. You typically compare data usage month over month, quarter over quarter, and year over year. Data cannot be updated after 30 months, but you sometimes have to access historical data that's up to 12 years old. In this case, you might consider the following ILM policies:
- 
                    Implement Advanced Compression. Take advantage of Oracle Heat Map and Automatic Data Optimization (ADO) with Advanced Compression. 
- 
                    Set up interval partitioning on the date column. 
- 
                    Use a function that drops partitions that are older than 14 years on a monthly basis. 
- 
                    Use read-only tablespaces to hold data that's more than 30 months old. The primary purpose of read-only tablespaces is to eliminate the need to perform backup and recovery of large, static portions of a database (when you use Oracle RMAN with Oracle on Amazon EC2). Read-only tablespaces also provide a way to protect historical data so that users cannot modify it. Making a tablespace read-only prevents updates on all tables in the tablespace, regardless of a user's update privilege level. 
Users often store active data, infrequently accessed data, and archive data in a
                single Oracle database. During your Oracle database migration to AWS, you can
                migrate infrequently accessed data, historical audit data, and archive data directly
                into Amazon S3
OEM integration
When you migrate your Oracle workloads to AWS, you might want to implement Oracle Enterprise Manager (OEM) Cloud Control on AWS. OEM is Oracle's management platform that provides a single interface for managing Oracle environments.
Oracle on Amazon EC2 and Amazon RDS for Oracle can be targets for an OEM environment. Oracle on Amazon EC2 follows the same process as Oracle on premises to integrate with OEM. To activate OEM on Amazon RDS for Oracle:
- 
                    Sign in to the AWS Management Console and open the Amazon RDS console at https://console.aws.amazon.com/rds/ . 
- 
                    In the navigation pane, choose Option Groups. 
- 
                    Add the OEM_AGENToption to a new or existing option group.
- 
                    Add OEM configuration information, including the OEM management server hostname, port, and OEM agent registration password. 
Amazon RDS for Oracle and Oracle on Amazon EC2 can also be targets for an OEM environment that's running on premises. However, this requires all OEM ports to be accessible through your firewall.
Amazon CloudWatch integration
Amazon CloudWatch collects monitoring and operational data in the form of logs, metrics, and events. It visualizes data by using automated dashboards that provide a unified view of AWS resources, applications, and services that run on AWS and on premises. Oracle databases that are hosted on Amazon EC2 and Amazon RDS for Oracle can use CloudWatch.
CloudWatch and Amazon Simple Notification Service (Amazon SNS) are integrated so you can collect, view, and analyze metrics for every active Amazon SNS notification. For example, you can set an alarm to send an email notification or SMS if a specified action, such as a specific Oracle error message in the Oracle Database alert log, occurs.
To use CloudWatch and Amazon SNS with Oracle on Amazon EC2, you must install a CloudWatch agent to push the Oracle alert log, audit logs, trace logs, OEM logs, and listener logs to CloudWatch. If you deploy Amazon RDS for Oracle, you must modify the Oracle instance to enable these logs to be sent to CloudWatch. For more information about CloudWatch integration, see Monitoring Amazon SNS topis using CloudWatch in the Amazon SNS documentation.
Amazon RDS for Oracle also has built-in CloudWatch alarms for dozens of events, including CPU utilization, number of database connections, available memory, free storage space, storage IOPS, disk throughput, and replication lag.
Most users who migrate from Exadata on premises to AWS continue to use OEM and also integrate CloudWatch with their Oracle databases on AWS.
Database optimizer statistics
Oracle Database optimizer statistics provide information about the database and its tables, columns, indexes, and the system. The optimizer uses this information to estimate the number of rows and bytes that are retrieved from a table, partition, or index for a query, to estimate the cost of access, and to pick the SQL execution plan that has the lowest cost.
If you restore an Exadata on-premises database to Amazon EC2 through Oracle RMAN,
                Oracle automatically provides statistics that reflect the Exadata environment. As
                soon as you restore the Exadata databases to Amazon EC2 or the initial load is
                completed in Amazon RDS for Oracle, it is best practice to gather statistics as soon
                as possible. This can be accomplished by running the Oracle DBMS_STATS package
AWR settings
The Oracle Automatic Workload Repository (AWR) stores performance-related statistics for an Oracle database. By default, Oracle Database generates snapshots once every hour, and retains the snapshots for 8 days. You can manually create or drop snapshots, and modify snapshot settings.
For production Oracle databases, you should increase the AWR retention period to 60 or 90 days and reduce the AWR interval to 15 or 30 minutes. These settings support month-over-month comparisons and provide more granularity when you view AWR data. These changes consume relatively small (measured in gibibytes) database space and provide the benefits of additional history. To set the AWR retention period to 60 days and the AWR interval to 15 minutes, run the following command (parameter values are in minutes):
BEGIN DBMS_WORKLOAD_REPOSITORY.modify_snapshot_settings (interval => 15, retention => 86400 ); END; /
If you migrate your Exadata on-premises database to Oracle on Amazon EC2 by using
                Oracle RMAN or Oracle Data Guard, you should drop the AWR snapshots captured while
                the database was running on Exadata. To do this, use the
                    DBMS_WORKLOAD_REPOSITORY.DROP_SNAPSHOT_RANGE procedure on
                AWS.
Oracle RAC considerations
By default, Exadata uses Oracle Real Application Clusters (RAC), which enable you to run a single Oracle database across multiple servers in order to maximize availability and enable horizontal scalability. Oracle RAC uses shared storage. The smallest Exadata offering includes two nodes that are configured by using Oracle RAC.
If you have an RPO requirement of zero and an RTO requirement of two minutes or less, you can implement Amazon RDS for Oracle with Multi-AZ. This configuration provides a monthly uptime commitment of 99.95%, which is equivalent to or better than any managed Oracle cloud database in the industry, including managed Oracle databases that use Oracle RAC.
Additionally, Oracle on Amazon EC2 lets you implement a highly available database by
                using many of the components in the Oracle Maximum Availability Architecture (MAA)
There are also various alternatives for implementing Oracle RAC on AWS. To find out more about RAC options on AWS, we recommend that you contact your AWS account team.
Additional best practices for homogeneous migrations
Developers often ignore SQL tuning techniques and best practices when they implement Exadata. Exadata hides many design issues, so SQL statements might get deployed into production without assessing their execution plans or resource consumption, because they complete within acceptable elapsed times. Follow these additional practices when you migrate your Exadata on-premises database to Oracle on AWS.
- 
                    Apply the latest Oracle Release Update (RU) or Release Update Revision (RUR). 
- 
                    Make sure that the COMPATIBLEinitialization parameter contains only three levels (for example, 19.0.0). If an upgrade takes place after you migrate to AWS, make sure that this parameter is modified during the upgrade process.
- 
                    Consider caching sequence numbers to minimize I/O. The default value is 20. If there is insufficient caching of sequence numbers, contention can occur, which will show up as an increase in service times for DML. 
- 
                    If you use sequences, validate the sequence values against the source database (Exadata on premises) to avoid sequence inconsistency. 
- 
                    If connection pooling isn't implemented on the application tier or the number of application tiers results in a very large number of database connections, consider implementing Oracle Database Resident Connection Pooling (DRCP) . This feature handles memory and compute resources on the database server efficiently. 
- 
                    Consider using HugePages. Oracle recommends that you use standard HugePages for Linux. Enabling HugePages makes it possible for the operating system to support memory pages that are greater than the default (usually 4 KB). Using very large page sizes can improve system performance by reducing the amount of system resources required to access page table entries. 
- 
                    If the Oracle database on AWS has database links, confirm that the OPEN_LINKSandOPEN_LINKS_PER_INSTANCEinitialization parameters aren't set to the default value (4). If this value is too low, SQL statements that have database links begin to queue when the maximum value is reached, which negatively impacts performance.
- 
                    The initial data load might not be able to be transmitted over the network. For example, theoretically it takes at least nine days with no interruptions to transfer 100 TiB over a 1 Gbps link. A better approach would be to use an AWS Snow Family device to migrate the database to AWS. 
- 
                    Remove any Exadata-specific hidden parameters (see Oracle MOS Note 1274318.1). These hidden Exadata initialization parameters shouldn't be activated on AWS. They can cause instability, performance problems, corruption, and crashes. 
- 
                    Try to resolve all non- SYSandSYSTEMinvalid objects after you migrate the data to Oracle on AWS.
- 
                    Consider caching static, frequently accessed tables in the Oracle System Global Area (SGA). 
- 
                    Choose memory optimized instances with larger Oracle SGA configurations to mitigate the challenge of additional I/O on AWS. You can use the Oracle SGA Advisory report during load testing in the target instance to find the optimal Oracle SGA configuration. 
- 
                    Create indexes on tables that handle many full table scans. The V$SEGMENT_STATISTICSview lists candidate segments.
- 
                    Identify top resource-intensive queries and optimize them for better execution plans. Oracle SQL Tuning Advisor, which is licensed under the Oracle Tuning Pack, can be useful for automatic SQL tuning. In some cases, you might need to rewrite queries or break down a complex query into smaller chunks. 
- 
                    Consider implementing caching solutions such as Amazon ElastiCache and Amazon RDS for Oracle read replicas, such as Oracle Active Data Guard, to serve read-only workloads. 
- 
                    Train your developers in query optimization techniques, and build standard operating procedures to assess queries before they are deployed to production. 
- 
                    Make sure that the database object count in AWS is the same as in the Exadata on-premises database. Validate tables, indexes, procedures, triggers, functions, packages, constraints, and other objects. 
- 
                    Consider application modifications if possible. (In some cases, applications can't be modified as with packaged ISV applications.) Avoid unnecessary calls and try to reduce the frequency of required calls. Try to minimize the data volume retrieved by SQL statements. Make sure that the commit frequency is appropriate for the business logic, but not excessive. Try to improve the use of application-level caching. 
- 
                    The database should reside in a private virtual private cloud (VPC) on AWS. Restrict network access for inbound and outbound traffic to a least privilege model. The security group source should refer to a security group in the AWS account, prefix lists, or a specific set of IP addresses (using the x.x.x.x/32 format). The security group source shouldn't use CIDR and security groups shouldn't be accessible from the public internet (0.0.0.0/0).