Migrate from Heroku to Supabase
Supabase is one of the best free alternatives to Heroku Postgres. This guide shows how to migrate your Heroku Postgres database to Supabase. This migration requires the pg_dump and psql CLI tools, which are installed automatically as part of the complete PostgreSQL installation package.
Alternatively, use the Heroku to Supabase migration tool to migrate in just a few clicks.
Quick demo#
Retrieve your Heroku database credentials #
- Log in to your Heroku account and select the project you want to migrate.
- Click Resources in the menu and select your Heroku Postgres database.
- Click Settings in the menu.
- Click View Credentials and save the following information:
- Host (
$HEROKU_HOST
) - Database (
$HEROKU_DATABASE
) - User (
$HEROKU_USER
) - Password (
$HEROKU_PASSWORD
)
- Host (
Retrieve your Supabase Host #
- If you're new to Supabase, create a project.
- Go to the Database settings for your project in the Supabase Dashboard.
- Under Connection Info, note your Host (
$SUPABASE_HOST
).
Export your Heroku database to a file #
Use pg_dump
with your Heroku credentials to export your Heroku database to a file (e.g., heroku_dump.sql
).
1pg_dump --clean --if-exists --quote-all-identifiers \ 2 -h $HEROKU_HOST -U $HEROKU_USER -d $HEROKU_DATABASE \ 3 --no-owner --no-privileges > heroku_dump.sql
Import the database to your Supabase project #
Use psql
to import the Heroku database file to your Supabase project.
1psql -h $SUPABASE_HOST -U postgres -f heroku_dump.sql
Additional options#
- To only migrate a single database schema, add the
--schema=PATTERN
parameter to yourpg_dump
command. - To exclude a schema:
--exclude-schema=PATTERN
. - To only migrate a single table:
--table=PATTERN
. - To exclude a table:
--exclude-table=PATTERN
.
Run pg_dump --help
for a full list of options.
caution
- If you plan on migrating a database larger than 6 GB, we recommend contacting support to ensure that you'll have the proper disk size pre-provisioned. You can read more about how the disk is managed on Supabase on the Database usage.
- We also recommend upgrading to at least a Large instance for the migration (you can downgrade later) to avoid running out of IO-Budget.