Skip to content

Restore RDS backup

This guide shows you how to restore a database backup to a new database cluster.

Before you begin

You need to:

  • complete Configure AWS Backup
  • have at least one snapshot available (by default a database backup is completed nightly)
  • configure RDS bastion to be able to verify your restored database
  • have psql installed to connect to your database

Step 1: Find a snapshot to restore

In the AWS console find the Amazon RDS service. Under Snapshots > Backup service select a DB snapshot to restore.

Activate incoming webhooks

Under Actions select Restore snapshot.

Activate incoming webhooks

Step 2: Configure your new database

Under Settings provide a name for the new database. The default from Golden Path is ${local.environment}-main. If you chose the name pirates-dev a cluster with the name pirates-dev-cluster will be created.

Activate incoming webhooks

Under Instance configuration select "Serverless v2". Update "Maximum capacity (ACUs)" as needed.

Activate incoming webhooks

Under Connectivity > Existing VPC security groups remove the default security group.

Activate incoming webhooks

Instead of the default security group we need the DB security group. You can find the name of this security group under your existing database Amazon RDS > Databases. Select your current DB instance (not cluster). Review the Security group rules to find the name of the current security group. Select the security group used for your current database like this:

Activate incoming webhooks

Finally, select Restore DB cluster. Restoring a database takes some time (approx. 30min for an empty database). While restoring the database will be listed as creating. Before continuing the database status must be "Available".

Step 3: Verify database backup

Assumption

In order to do this step you must already have RDS bastion configured. If you do not have RDS bastion configure, see Connect to a database from your computer

Using the ok tool enable access to the database from your local machine with:

ok forward #Follow the prompts and select your newly restored database.

In another terminal type:

psql --host=localhost --port=4812 --username=root --password --dbname=postgres

The master password will be the same as for the old database. If you do not know the old password, you can update it to a known value from the console Amazon RDS > Databases > (Select restored DB) > (Modify). Set a new master password and apply the configuration.

You should now be able to verify that the content of your database is as expected and can proceed to connect your application to the new database.

Step 4: Connect app to new database

This step assumes that you are following the Golden Path and details may vary depending on your setup.

In your application stack, create a new SSM parameter as follows:

resource "aws_ssm_parameter" "db_endpoint" {
  name  = "/${local.environment}/database/${local.db_name}/restored_db_endpoint"
  type  = "String"
  value = "To be set in console"
  tags  = local.common_tags

  lifecycle {
    ignore_changes = [
      value
    ]
  }
}

Create the new resource by running terraform apply.

Locate the database endpoint in the console under Amazon RDS > Databases > (Select your restored DB instance). Copy the database endpoint.

Update the value of the newly created parameter under AWS Systems Manager > Parameter Store > (Search for restored_db_endpoint).

Step 5: Update the App DB endpoint

Create a new file called __gp_dependencies_override.tf with the following:

data "aws_ssm_parameter" "db_endpoint" {
  name            = "/${local.environment}/database/${local.db_name}/restored_db_endpoint"
  with_decryption = false
}

Run terraform apply again to update your application.

Next step

Warning

The above approach assumes that the username and password for the database will remain the same. If you rotate the password on the old database you will experience connectivity issues with the restored database.

Once you have restored your application to a working state you should import the new database into your Terraform configuration for easier management.