Upgrading PostgreSQL on Heroku: A Step-by-Step Guide

jetthoughts-dev

JetThoughts Dev

Posted on February 14, 2024

Upgrading PostgreSQL on Heroku: A Step-by-Step Guide

Are you looking to upgrade your PostgreSQL database on Heroku? Whether it's for performance improvements or staying up-to-date with the latest features, upgrading your database is a crucial task. In this guide, we'll walk you through the process of upgrading PostgreSQL on Heroku with clear, step-by-step instructions.

1. Create a DB Follower

The first step in the PostgreSQL upgrade process is to create a database follower. This is essential for minimizing downtime during the upgrade.

heroku addons:create heroku-postgresql:standard-0 --follow HEROKU_POSTGRESQL_OLD --app your_app_name
Enter fullscreen mode Exit fullscreen mode

Replace HEROKU_POSTGRESQL_OLD_URL, standard-0, and your_app_name with values specific for your app configuration.
Wait for the follower to start up:

heroku pg:wait --app your_app_name

# You can check the follower's status
heroku pg:info --app your_app_name
Enter fullscreen mode Exit fullscreen mode

Wait for the follower to catch up, we'll need the follower to be fully in sync to minimize the downtime. In the follower DB info it should contain Behind By: 0 commits.

2. Turn on Maintenance Mode

To ensure a smooth upgrade process, it's recommended to turn on maintenance mode for your app.

heroku maintenance:on --app your_app_name

# Check the maintenance status
heroku maintenance --app your_app_name
Enter fullscreen mode Exit fullscreen mode

3. Upgrade the Follower

Before upgrading, confirm that the follower has caught up fully:

heroku pg:info --app your_app_name
# Should have Behind By:   0 commits
Enter fullscreen mode Exit fullscreen mode

Now, proceed with the upgrade:

heroku pg:upgrade HEROKU_POSTGRESQL_FOLLOWER_URL --app your_app_name

heroku pg:wait --app your_app_name
Enter fullscreen mode Exit fullscreen mode

4. Promote the Follower

Promote the upgraded follower to be the new primary database:

heroku pg:promote HEROKU_POSTGRESQL_FOLLOWER_URL --app your_app_name
Enter fullscreen mode Exit fullscreen mode

5. Stop Maintenance Mode

Once the upgrade and promotion are complete, turn off maintenance mode:

heroku maintenance:off --app your_app_name

# Verify the status:
heroku pg:info --app your_app_name
Enter fullscreen mode Exit fullscreen mode

6. Ensure that the app works correctly & all app data is present.

Make sure that all parts of the app are using the new DB, perform automated & manual checks to verify that everything works as expected. You can wait a couple of days/weeks (in case if there are some daily/weekly background jobs/tasks) to ensure that there're no longer requests to the old DB.
In case of any issues found on this step you can quickly switch back to using the old DB, fix them & repeat the upgrade steps at a later time.

7. Destroy the Old Database

Finally, you can safely destroy the old database to clean up resources:

heroku addons:destroy HEROKU_POSTGRESQL_OLD --app your_app_name
Enter fullscreen mode Exit fullscreen mode

Congratulations! You have successfully upgraded your PostgreSQL database on Heroku. This process ensures minimal downtime and a smooth transition to the latest version. Keep in mind that database upgrades should be performed with caution, and it's recommended to have backups in place before initiating any major changes.

Further improvements

To minimize downtime, you can consider configuring you app to use multiple database setup: with primary/replica DBs. Instead of switching maintenance mode on, you can switch to read-only mode. There's a gem called rails_failover that makes the set up easier.

💖 💪 🙅 🚩
jetthoughts-dev
JetThoughts Dev

Posted on February 14, 2024

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related