2019-01-01 14:40:48 +02:00
# Importing an existing Postgres database from another installation (optional)
2020-12-14 01:48:36 +02:00
Run this if you'd like to import your database from a previous installation.
(don't forget to import your Synapse `media_store` files as well - see [the importing-synape-media-store guide ](importing-synapse-media-store.md )).
2019-01-01 14:40:48 +02:00
## Prerequisites
For this to work, **the database name in Postgres must match** what this playbook uses.
2021-01-22 15:50:24 +02:00
This playbook uses a Postgres database name of `synapse` by default (controlled by the `matrix_synapse_database_database` variable).
If your database name differs, be sure to change `matrix_synapse_database_database` to your desired name and to re-run the playbook before proceeding.
2019-01-01 14:40:48 +02:00
The playbook supports importing Postgres dump files in **text** (e.g. `pg_dump > dump.sql` ) or **gzipped** formats (e.g. `pg_dump | gzip -c > dump.sql.gz` ).
2022-10-06 12:22:52 +02:00
Importing multiple databases (as dumped by `pg_dumpall` ) is also supported.
2022-10-06 12:23:48 +02:00
But the migration might be a good moment, to "reset" a not properly working bridge. Be aware, that it might affect all users (new link to bridge, new rooms, ...)
2019-10-05 10:28:26 +02:00
2019-01-01 15:35:33 +02:00
Before doing the actual import, **you need to upload your Postgres dump file to the server** (any path is okay).
2019-01-01 14:40:48 +02:00
## Importing
2023-03-16 11:23:22 +02:00
To import, run this command (make sure to replace `SERVER_PATH_TO_POSTGRES_DUMP_FILE` with a file path on your server):
2019-01-01 14:40:48 +02:00
2021-01-22 17:39:08 +02:00
```sh
2023-03-16 11:23:22 +02:00
just run-tags import-postgres \
--extra-vars=server_path_postgres_dump=SERVER_PATH_TO_POSTGRES_DUMP_FILE \
2023-03-17 08:27:25 +02:00
--extra-vars=postgres_default_import_database=matrix
2021-01-22 17:39:08 +02:00
```
2022-10-06 12:22:52 +02:00
**Notes**:
2023-03-16 11:23:22 +02:00
- `SERVER_PATH_TO_POSTGRES_DUMP_FILE` must be a file path to a Postgres dump file on the server (not on your local machine!)
2023-03-17 08:27:25 +02:00
- `postgres_default_import_database` defaults to `matrix` , which is useful for importing multiple databases (for dumps made with `pg_dumpall` ). If you're importing a single database (e.g. `synapse` ), consider changing `postgres_default_import_database` accordingly
2020-07-13 16:03:24 +02:00
2021-01-22 17:39:08 +02:00
2020-07-13 16:03:24 +02:00
## Troubleshooting
2021-12-05 10:41:00 +02:00
### Table Ownership
2020-07-13 16:03:24 +02:00
A table ownership issue can occur if you are importing from a Synapse installation which was both:
- migrated from SQLite to Postgres, and
- used a username other than 'synapse'
In this case you may run into the following error during the import task:
```
"ERROR: role \"synapse_user\" does not exist"
```
where `synapse_user` is the database username from the previous Synapse installation.
This can be verified by examining the dump for ALTER TABLE statements which set OWNER TO that username:
```Shell
2021-11-30 23:07:04 +02:00
$ grep "ALTER TABLE" homeserver.sql
2020-07-13 16:03:24 +02:00
ALTER TABLE public.access_tokens OWNER TO synapse_user;
ALTER TABLE public.account_data OWNER TO synapse_user;
ALTER TABLE public.account_data_max_stream_id OWNER TO synapse_user;
ALTER TABLE public.account_validity OWNER TO synapse_user;
ALTER TABLE public.application_services_state OWNER TO synapse_user;
...
```
It can be worked around by changing the username to `synapse` , for example by using `sed` :
2020-07-13 16:12:17 +02:00
```Shell
2021-11-30 23:07:04 +02:00
$ sed -i "s/OWNER TO synapse_user;/OWNER TO synapse;/g" homeserver.sql
2020-07-13 16:03:24 +02:00
```
2021-11-30 23:07:04 +02:00
This uses sed to perform an 'in-place' (`-i`) replacement globally (`/g`), searching for `synapse_user` and replacing with `synapse` (`s/synapse_user/synapse`). If your database username was different, change `synapse_user` to that username instead. Expand search/replace statement as shown in example above, in case of old user name like `matrix` - replacing `matrix` only would... well - you can imagine.
2020-07-13 16:03:24 +02:00
Note that if the previous import failed with an error it may have made changes which are incompatible with re-running the import task right away; if you do so it may fail with an error such as:
```
ERROR: relation \"access_tokens\" already exists
```
2021-12-05 10:41:00 +02:00
### Repeat import
2020-07-13 16:03:24 +02:00
In this case you can use the command suggested in the import task to clear the database before retrying the import:
```Shell
# systemctl stop matrix-postgres
# rm -rf /matrix/postgres/data/*
# systemctl start matrix-postgres
```
2023-03-16 11:23:22 +02:00
Now on your local machine run `just run-tags setup-postgres` to prepare the database roles etc.
2021-12-05 10:41:00 +02:00
If not, you probably get this error. `synapse` is the correct table owner, but the role is missing in database.
```
"ERROR: role synapse does not exist"
```
2022-10-06 12:22:52 +02:00
Once the database is clear and the ownership of the tables has been fixed in the SQL file, the import task should succeed.
2021-12-05 10:41:00 +02:00
Check, if `--dbname` is set to `synapse` (not `matrix` ) and replace paths (or even better, copy this line from your terminal)
```
2022-11-27 09:16:18 +02:00
/usr/bin/env docker run --rm --name matrix-postgres-import --log-driver=none --user=998:1001 --cap-drop=ALL --network=matrix --env-file=/matrix/postgres/env-postgres-psql --mount type=bind,src=/migration/synapse_dump.sql,dst=/synapse_dump.sql,ro --entrypoint=/bin/sh docker.io/postgres:15.0-alpine -c "cat /synapse_dump.sql | grep -vE '^(CREATE|ALTER) ROLE (matrix)(;| WITH)' | grep -vE '^CREATE DATABASE (matrix)\s' | psql -v ON_ERROR_STOP=1 -h matrix-postgres --dbname=synapse"
2021-12-05 10:41:00 +02:00
```
### Hints
2022-11-27 09:16:18 +02:00
To open psql terminal run `/matrix/postgres/bin/cli`