Introduction
Amazon Relational Database Service (Amazon RDS) is a fully managed relational database service provided by Amazon Web Services (AWS). It allows you to set up, operate, and scale a relational database in the cloud with ease. In this blog post, we will walk through the process of creating a Free tier RDS instance of MySQL, setting up an EC2 instance, creating an IAM role with RDS access, and connecting the EC2 instance to the RDS instance.
For those interested in deploying a comprehensive two-tier application architecture on AWS, you may also want to check out our earlier guide: Deploying a Two-Tier Application with MySQL on Amazon RDS. This tutorial provides valuable insights into the benefits of a two-tier architecture and covers the essential steps for setting up a seamless connection between an EC2 instance and an Amazon RDS database.
Step 1: Create a Free Tier RDS Instance of MySQL
Log in to your AWS Management Console.
Navigate to the Amazon RDS service.
Click on "Create database."
Choose the "MySQL" engine and select the "Free tier" template.
Configure the settings, including DB instance identifier, master username, and password.
Set the remaining configurations such as DB instance size, storage, and networking options.
Review your configurations and click "Create database."
Wait for the RDS instance to be created. Once it's available, note down the endpoint for future reference.
Step 2: Create an EC2 Instance
Navigate to the Amazon EC2 service in the AWS Management Console.
Click on "Instances" in the left-hand navigation pane.
Click "Launch Instance."
Choose an Amazon Machine Image (AMI), such as Amazon Linux 2 or Ubuntu.
Select an instance type, and configure instance details, storage, and security groups.
Review your configurations and click "Launch."
Create or select an existing key pair to securely connect to your EC2 instance.
Launch the instance and wait f
or it to become running.
Step 3: Create an IAM Role with RDS Access
Navigate to the IAM service in the AWS Management Console.
Click on "Roles" in the left-hand navigation pane.
Click "Create role."
Choose "Amazon EC2" as the service that will use this role.
Attach the "AmazonRDSFullAccess" policy to the role to grant RDS access.
Review the configuration and click "Create role."
Step 4: Assign the Role to EC2
Go back to the EC2 service in the AWS Management Console.
Select the EC2 instance you created earlier.
Click on "Actions" > "Security" > "Modify IAM Role."
Choose the IAM role you created in Step 3 and save the changes.
Step 5: Connect EC2 to RDS
SSH into your EC2 instance using the key pair you created.
Install the MySQL client on the EC2 instance:
sudo apt-get install mysql-client
Use the following command to connect to your RDS instance from the EC2 instance, replacing
<RDS_ENDPOINT>
,<DB_USERNAME>
, and<DB_PASSWORD>
with your actual values:mysql -h <RDS_ENDPOINT> -u <DB_USERNAME> -p<DB_PASSWORD>
You will be prompted to enter the password.
Once connected, you can start working with your MySQL database on RDS from your EC2 instance.
Congratulations! You have successfully set up an Amazon RDS instance, an EC2 instance, created an IAM role with RDS access, assigned the role to EC2, and connected the EC2 instance to the RDS instance using a MySQL client. This hands-on tutorial should help you get started with managing relational databases on AWS.
Follow me on LinkedIn.
Checkout my GitHub profile.