Import PostgresSQL
Overview
In this guide, we will see how to export a PostgreSQL database from your current setup and import it into the PostgreSQL database of a Cloudron app.
Dump
The first step is to create a dump of your existing PostgreSQL database. This can be done
using pgdump
:
$ PGPASSWORD=password pg_dump --no-owner --no-privileges --username=username --host=myserver databasename > pgdump.sql
If this database is on a Cloudron, you can use the following command:
# PGPASSWORD=${CLOUDRON_POSTGRESQL_PASSWORD} pg_dump --no-owner --no-privileges --username=${CLOUDRON_POSTGRESQL_USERNAME} --host=${CLOUDRON_POSTGRESQL_HOST} ${CLOUDRON_POSTGRESQL_DATABASE} > /tmp/pgdump.sql
Import
- After install, enable 'Recovery Mode'in the
Repair
section. This will ensure that the app is paused and not actively using the database when you are importing.
data:image/s3,"s3://crabby-images/e150e/e150eb204f374c9cc0dc2e57c4a864a0f81b013a" alt=""
- Open a Web Terminal by using the Terminal button in the
Console
section.
data:image/s3,"s3://crabby-images/ab2dd/ab2dd220f1b586ec88f97e150d00966b36b2a389" alt=""
- Upload the dump file using the
Upload
button.
data:image/s3,"s3://crabby-images/f34a4/f34a4168107d8addfb7f00c5302a6410b1f6e283" alt=""
- The dump file might contain extension information that needs to be first commented out.
# sed -e 's/CREATE EXTENSION/-- CREATE EXTENSION/g' -e 's/COMMENT ON EXTENSION/-- COMMENT ON EXTENSION/g' /tmp/pgdump.sql > /tmp/pgdump_mod.sql
- Clear the existing database
# PGPASSWORD=${CLOUDRON_POSTGRESQL_PASSWORD} psql -h ${CLOUDRON_POSTGRESQL_HOST} -p ${CLOUDRON_POSTGRESQL_PORT} -U ${CLOUDRON_POSTGRESQL_USERNAME} -d ${CLOUDRON_POSTGRESQL_DATABASE} -c "DROP SCHEMA public CASCADE; CREATE SCHEMA public"
- Finally, import the dump using the
psql
command:
# PGPASSWORD=${CLOUDRON_POSTGRESQL_PASSWORD} psql -h ${CLOUDRON_POSTGRESQL_HOST} -p ${CLOUDRON_POSTGRESQL_PORT} -U ${CLOUDRON_POSTGRESQL_USERNAME} -d ${CLOUDRON_POSTGRESQL_DATABASE} --set ON_ERROR_STOP=on --file=/tmp/pgdump_mod.sql
Verify
Click the PostgreSQL
button on top of the terminal to paste the command line required to access the PostgreSQL database.
You can now press enter/return to get the PostgreSQL shell.
data:image/s3,"s3://crabby-images/2d594/2d594952a29a8da8406a70d0cff80ead51e4e37d" alt=""