Table of Contents
There are times when we want to scale up the existing databases deployed on the Amazon Aurora which is in house relational database written and created by Amazon itself from scratch. So today we are going to look at creating an “Aurora Read Replica of an RDS instance“.
Before going further, make sure you follow this -> MYSQL Database on Amazon RDS post because upcoming steps can only be performed when we have a running RDS instance, which we learned in that post, this post is in the continuation of that post.
Step 1: Create Aurora Read Replica
We have to select the RDS database instance of which we want to create aurora read replica. As can be seen from the image below, we first select the “geekylanedb” then from the “Actions” menu we have selected the “Create Aurora read replica” option.
data:image/s3,"s3://crabby-images/785b8/785b8e65d42841b6b8c7421c10cf19edd82d8c43" alt="Under actions select create aurora read replica"
Instance specifications
It is time to provide specifications for our “Aurora Read Replica” instance. We have provided the following details:
- DB engine version = Aurora (MySQL)-5.7.12
- DB instance class = db.t2.small – 1 vCPU, 2 GiB RAM
- Multi-AZ deployment = Create Replica in Different Zone
data:image/s3,"s3://crabby-images/2fb35/2fb35cd786720bbbdf48989123ef396b90928669" alt="Create Aurora read replica - Instance Specifications"
Settings
A few more need to be provided, are as follows:
- DB instance identifier = geekylane-auroraDB
data:image/s3,"s3://crabby-images/e6c87/e6c87e0f5da07802d03a8d29dd9cd94e53916e35" alt="Create Aurora read replica - Settings"
Network & Security
We also have to provide some network and security related details as well:
- Virtual Private Cloud (VPC) = Default
- Subnet group = default
- Public accessibility = Yes
- Availability Zone = No preference
- VPC security groups = Create a new VPC security group
data:image/s3,"s3://crabby-images/78744/787448efc67232179c73d6b941a6c10feb389798" alt="Create Aurora read replica Network and Security"
Database Options
Some database related details are required for creating “Aurora Read Replica of an RDS Instance“, those details are as follows:
- Database port = 3306
- DB parameter group = default.aurora-mysql5.7
data:image/s3,"s3://crabby-images/a1d55/a1d55f18563f5a84f9b32b6be68fc636494916c4" alt="Create Aurora read replica - Database Options"
Encryption
For this, we have to specify whether we want to encrypt the data on the “Aurora Read Replica DB instance” or not. As of now, we have selected the “Disable encryption” option.
data:image/s3,"s3://crabby-images/c8708/c87082a6b85352a68869b0efef57c2f9ccaed17f" alt="Create Aurora read replica - Encryption"
Failover
Priority, here we have selected the “No preference“.
data:image/s3,"s3://crabby-images/16fd7/16fd7f1966daaaf7adf5387613f96703747e7b1f" alt="Create Aurora read replica - Fail-over"
Backup
In this option, we are enabling the “Automatic Backups“, also we have specified about “up to how many days the Amazon should keep the backup“, we want it for only “1 day“.
data:image/s3,"s3://crabby-images/fe0e3/fe0e3fd2ad7dc374ac3e7609558311beb8911e63" alt="Create Aurora read replica - Backup"
Monitoring
We have enabled the monitoring for this instance, with the following options:
- Monitoring Role = Default
- Granularity = 60 seconds
data:image/s3,"s3://crabby-images/666d2/666d2290b71941ccf1f4b0761f56e39482f15af2" alt="Create Aurora read replica - Monitoring"
Log exports
We left it all blank because we do not want any kind of logs to be logged.
data:image/s3,"s3://crabby-images/c1d46/c1d46bd2b9463d4b33c7971306d112e4e878ff9c" alt="Create Aurora read replica - Log exports"
Maintenance
Also, we do want the “Auto minor version upgrade” so we selected the “Yes” option. Moreover, we also have to specify the “Maintenance Window“, we have opted for the “No preference” option.
data:image/s3,"s3://crabby-images/e92f9/e92f9364daeee40f074a71b1bd2ac8f8ed3c79d9" alt="Create Aurora read replica - Maintenance"
After doing all the things mentioned above, you will be seeing a button like shown below, simply click on Create read replica button.
data:image/s3,"s3://crabby-images/d3811/d38119f319f1e036c503a17550ca390445cca65d" alt="Create Read Replica"
Status = Creating
After doing all the steps, it is going to take a few minutes in order to create “2 instances“.
Note: Both the instances do have their own unique names, but they come under a unique name “geekylane-auroradb-cluster“.
Also, both the instances are going to be created in different, which is Amazon AWS intelligence.
data:image/s3,"s3://crabby-images/d361f/d361ff2a11e455e13966c21f80a78f1c52c397f4" alt="Creating Read Replicas"
Status = Backing-up
Before it creates the final cluster, the Amazon AWS is going to “back up” the original “Amazon RDS DB instance“.
From the picture below, we can confirm that.
data:image/s3,"s3://crabby-images/539db/539db294219a0cffc3261149f6f63a3606e81623" alt="Backing up original database"
Status = Preparing-data-migration
After backing up the original RDS DB instance, the instance is “Available” again.
Also, now the cluster is migrating the data from the original instance to the “Aurora Read Replica cluster“.
data:image/s3,"s3://crabby-images/9462d/9462dc11559fa09523e408684f6c67fcd8bdd188" alt="Original is available again but aurora is migrating"
Status = Available
From the screenshot below, we can see that the status of all the instances (original + new) has been changed to “Available“, which means that our “Aurora Read Replica DB instance” has been successfully deployed.
data:image/s3,"s3://crabby-images/b41be/b41be87cc22afb2e36586a9bd0454e0aa21bfb9f" alt="Available now"
Step 2: Promote the Aurora Read Replica DB cluster
Now, we want to promote our newly created “Aurora Read Replica DB cluster“, and in order to do that, we have to select the “Actions” menu from there we have selected the “Promote” option, as shown in the picture below.
data:image/s3,"s3://crabby-images/d05e7/d05e785be72499e3235e10db88349dcd5a331407" alt="Promote database to be a read alone database"
Step 3: Delete the original RDS instance
It is time to delete our original base RDS instance and to do that, again select the instance and go to the “Actions” menu and from there select the “Delete” option as shown in the screenshot below.
data:image/s3,"s3://crabby-images/08b9e/08b9e172029bae9918ac6203d7ce4efcf6914e08" alt="Deleting the original mysql database"
It is going to ask you for the confirmation on instance deletion, and a screen similar below is going to be shown to you.
Simply type the “delete me” and select the “I acknowledge….” option. After that click on the Delete button.
data:image/s3,"s3://crabby-images/0a83f/0a83fd631223478a8521ed49ab4be956ace02099" alt="Confirmation for deletion"
Status = Deleting
Firstly, it is going to create the original RDS DB instance and the status is going to change to “Deleting“.
data:image/s3,"s3://crabby-images/a1d81/a1d81b96a6205e1557f9cb354d299d30164f94ec" alt="Status - deleting"
Step 4: Stop the Aurora Read Replica Cluster
It is going to be a long step, and we want to cover each and every aspect of this step that is why we have provided images for each process-step.
First of all, in order to start the “Aurora Read Replica Cluster” process, we have to select the “Actions” menu and from there we have to select the “Stop” option, as shown in the photo below.
data:image/s3,"s3://crabby-images/0ce5a/0ce5a41c20fde8d2e5c782b5de3a8118adf1b853" alt="Stop amazon aurora database instance"
It is going to ask for the confirmation and you will be seeing a screen as shown below. Click on the Stop database button.
data:image/s3,"s3://crabby-images/15fdf/15fdf6e1200211eecc08672793caa4538ae1fcf5" alt="Stop database warning"
Status = Stopping
The status of the cluster has been changed to “Stopping“.
data:image/s3,"s3://crabby-images/c15d9/c15d9251e0b2b1099b2eeb036fe873a6ea8a3097" alt="Status - stopping"
Soon, you will be seeing something as shown below. The status of both the instances in the cluster will be going to be changed to “Stopping” as well.
data:image/s3,"s3://crabby-images/4742e/4742eac49656009955c3e72e0f62e949211acfd1" alt="Status - all aurora read replicas are stopping"
Status = Stopped
Notice that the status of the “Reader” instance is going to be changed to “Stopped” first.
data:image/s3,"s3://crabby-images/15d23/15d23871fed35b96c3f3455eae5f464cafb67d27" alt="Reader Instance has been stopped"
After that, the “Writer” instance is going to get changed to “Stopped“.
data:image/s3,"s3://crabby-images/c3049/c3049a0f1e20445a8aab9afa096aeb8e6a83e97c" alt="Writer Instance has also stopped"
Soon, the overall status is going to be changed to “Stopped“.
data:image/s3,"s3://crabby-images/da7c9/da7c91d964c24d9cb6884db0979993b503396097" alt="Full cluster has been stopped"
Note: Although we have stopped the Aurora Read Replica cluster in the previous step, in order to delete it, we have to first start it again. Also to confirm that, you can see the picture below for the reference, as it is not showing any “Delete” option for the cluster.
data:image/s3,"s3://crabby-images/6af81/6af8171886749e59ef04971c7fce5117f1d097b5" alt="We cannot delete the aurora cluster at once"
Step 5: Delete the Aurora Read Replica Cluster
From the options under the “Action” menu, we have selected the “Delete” option particularly for the “Reader instance“.
data:image/s3,"s3://crabby-images/2fe8f/2fe8f9566314ca076b6cafce2c7723b1e1051e80" alt="Delete the Reader Instance first"
Note: The “database is not started” warning is going to pop up and we have manually “Start this database“.
data:image/s3,"s3://crabby-images/152b8/152b8c9e22829a6ad69236dd07e4efe7c6e1240e" alt="To delete any cluster instance we need to start the cluster first"
The status of the cluster is going to be changed to “Available“.
Firstly, it is going to start the “Writer” instance.
data:image/s3,"s3://crabby-images/4ac12/4ac12cf6e355eb09b7b0ac9f0a9f1d5cc3489415" alt="It is starting the amazon aurora cluster"
No, the status of the “Writer” instance is going to be changed to “Available“.
data:image/s3,"s3://crabby-images/1fff9/1fff95e8f59b5a89438f3f147bae2c65dab81ac5" alt="After one is started it is going to start others in the cluster"
Status = Available
The status of the whole cluster is now changed to “Available“.
data:image/s3,"s3://crabby-images/c10e4/c10e489d2e43c7af6823234f45299c99abe6df63" alt="The cluster is up now"
Now that the cluster it up and “Available” again, it is time to delete it.
Delete – Reader DB instance
If we click on “Delete” for the “Reader” instance, it is not going to give us the “Start the Database” warning.
data:image/s3,"s3://crabby-images/c7007/c7007ec39af725b1fcc64570330368269df2e9de" alt="Deleting the Reader Instance"
But, it is going to ask for the deletion confirmation, you simply have to write “delete me” and click on the Delete button
data:image/s3,"s3://crabby-images/5269a/5269a7b1560f63acc253cd84ea837857d7fc04be" alt="Delete confirmation"
First of all, the “Reader” instance is going to be deleted.
data:image/s3,"s3://crabby-images/183e7/183e7f30086fe722334f8af826319a73364ca192" alt="Read Instance has been deleted"
Delete – Writer DB instance
After that, we have to separately delete the “Writer instance“.
data:image/s3,"s3://crabby-images/f3acb/f3acb5f14b9fcb5862ac73a44b5b2c9603401924" alt="Delete writer Instance"
Simply type the “delete me” and select the “I acknowledge….” option. After that click on the Delete button.
data:image/s3,"s3://crabby-images/612ca/612ca9d23bea21d6012567e795160a23879caf1d" alt="Delete Confirmation"
Status = Deleting
data:image/s3,"s3://crabby-images/483e9/483e9f17371fe7ca2c1981fbfaed83a1f4723004" alt="Full aurora cluster is being deleted"
The Aurora Read Replica of an RDS Instance has been successfully deleted
data:image/s3,"s3://crabby-images/0b5df/0b5df0791392592d74ee5b5fcd21aa1d3986e6f5" alt="Aurora cluster has been deleted"
More on AWS:
- Set-up Read Replica for an RDS instance on AWS (Step-by-Step)
- Set-up WordPress on aws with EC2 and Amazon RDS (Step-by-Step)
- Install docker on AWS EC2 Ubuntu 18.04 (script method)
Comment here