Database migration from a simulated on-premises MS SQL Server to an Amazon RDS instance in AWS Cloud
An AWS CloudFormation template that deploys AWS Database Migration Service (AWS DMS) to continuously migrate tables from an MS SQL Server database to an Amazon Relational Database Service (RDS) instance.
This repository demonstrates the ease of database migration from an on-premises SQL Server to an Amazon RDS instance.
Deployment of this template will create two separate "environments". The first, an Amazon EC2 instance running an MS SQL Server represents an on-premises environment and is therefore the source while the second environment, an Amazon RDS SQL Server instance is the target for the migration.
The database is migrated using AWS DMS. It continuously synchronises changes in the "on-premises" instance with the cloud RDS instance.
This sample will deploy two SQL Server instances, one on EC2 and one on Amazon RDS, in their own VPCs. The SQL Server running on the EC2 instance represents the on-premises infrastructure, and the Amazon RDS instance represents AWS cloud. No tables will be created at this point - creating of tables inside the database is left to the user. AWS DMS migration task will also be created. Upon starting that task (eg; using console or aws cli), tables in the database will be continually replicated across from the EC2 instance to the Amazon RDS instance.
The AWS DMS demo uses:
- AWS Database Migration Service (DMS) to migrate and provide continuous replication of a database.
- Amazon Relational Database Service (RDS) as a target database to replicate to.
- Amazon EC2 as a source database for simulating an on-premises database server to migrate from.
- Amazon Virtual Private Cloud to launch AWS resources in a logically isolated virtual network.
An overview of the architecture is below:
To deploy the solution, you will require an AWS account. If you don’t already have an AWS account, create one at https://aws.amazon.com by following the on-screen instructions. Your access to the AWS account must have IAM permissions to launch AWS CloudFormation templates that create IAM roles.
The application is deployed as an AWS CloudFormation template.
Note You are responsible for the cost of the AWS services used while running this sample deployment. There is no additional cost for using this sample. For full details, see the pricing pages for each AWS service you will be using in this sample. Prices are subject to change.
- Deploy the latest CloudFormation template by following the link below for your preferred AWS region:
Region | Launch Template |
---|---|
US East (N. Virginia) (us-east-1) | |
US West (Oregon) (us-west-2) | |
EU (Ireland) (eu-west-1) | |
EU (London) (eu-west-2) | |
EU (Frankfurt) (eu-central-1) | |
AP (Sydney) (ap-southeast-2) |
- If prompted, login using your AWS account credentials.
- You should see a screen titled "Create Stack" at the "Specify template" step. The fields specifying the CloudFormation template are pre-populated. Click the Next button at the bottom of the page.
- On the "Specify stack details" screen you may customize the following parameters of the CloudFormation stack:
Parameter label | Default | Description |
---|---|---|
Availability Zones | Requires input | The list of Availability Zones to use for the subnets in the VPCs. Use two AZs. |
On premise CIDR IP | Requires input | The CIDR Allowed RDP and SQL access to the EC2 and RDS host. CIDR block parameter must be in the form x.x.x.x/0-32. |
DMSInstanceClass | dms.t3.large | Instance class of DMS instance. |
EC2 instance type | m5.2xlarge | The EC2 instance type for Microsoft SQL server. |
Windows server AMI | /aws/service/ami-windows-latest/Windows_Server-2019-English-Full-SQL_2016_SP3_Standard | Query for the Latest Windows AMI Using Systems Manager Parameter Store https://aws.amazon.com/blogs/mt/query-for-the-latest-windows-ami-using-systems-manager-parameter-store/ |
MSSQL Server version | 13 | MSSQL Server version. This is used to Change Auth mode from Windows only to SQL and Windows Auth. For MSSQL server 2017 use number 14, for MSSQL server 2016 use number 13. |
RDS instance type | db.m5.large | Instance class of RDS instance. |
Database engine type | sqlserver-se | MS SQL engine type. The Enterprise, Standard, Workgroup, and Developer editions are supported. The Web and Express editions aren't supported by AWS DMS. |
Database engine version | 13.00.6435.0.v1 | SQL Server 2016 SP2 (CU3) engine version13.00.5216.0, for all editions and all AWS Regions. |
Windows server and database username | dms_user | The database and instance admin account. Minimum 5 characters must begin with a letter and contain only alphanumeric or "_". |
Windows server and database password | Requires input | The password for instance user account. Minimum 8 characters, at least one of each of the following; uppercase, lowercase, number, and symbol character such as !@#$%^&*()<>[]{} |
Database name | dms_sample | Database name. |
When completed, click Next
-
Configure stack options if desired, then click Next.
-
On the review you screen, you must check the boxes for:
- "I acknowledge that AWS CloudFormation might create IAM resources"
- "I acknowledge that AWS CloudFormation might create IAM resources with custom names"
- "I acknowledge that AWS CloudFormation might require the following capability: CAPABILITY_AUTO_EXPAND"
These are required to allow CloudFormation to create a Role to allow access to resources needed by the stack and name the resources in a dynamic way.
-
Click Create Stack
-
Wait for the CloudFormation stack to launch. Completion is indicated when the "Stack status" is "CREATE_COMPLETE".
- You can monitor the stack creation progress in the "Events" tab.
-
Note the EC2SQLServerEip and RDSSQLEndpoint displayed in the Outputs tab of the main stack. This can be used to access the EC2 host and RDS instance.
- MSSQL server 2017 doesn't support continues replication. The solution is using MSSQL server 2016 by default.
See Local Development guide to get a copy of the project up and running on your local machine for development and testing purposes.
To remove the stack:
- Open the AWS CloudFormation Console
- Click the aws-dms-sql-server project, right-click and select "Delete Stack"
- Your stack will take some time to be deleted. You can track its progress in the "Events" tab.
- When it is done, the status will change from "DELETE_IN_PROGRESS" to "DELETE_COMPLETE". It will then disappear from the list.
Contributions are more than welcome. Please read the code of conduct and the contributing guidelines.
This sample code is made available under a modified MIT license. See the LICENSE file.