mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-07 08:13:18 +03:00
b2ac4d82bc
Recent versions of Docker Compose no longer support this, instead just printing a warning. PR-URL: https://github.com/hasura/graphql-engine-mono/pull/10937 GitOrigin-RevId: 97a82968c48f5c09d6cbe74d8ea7386979e46e7a |
||
---|---|---|
.. | ||
docker-compose.yaml | ||
init-primary.sh | ||
README.md |
Testing PostgreSQL read replication
This provides a Docker Compose file that starts up a PostgreSQL primary server and a single read replica.
We can use this to test how the HGE Server and Console behave when communicating with a read replica.
Starting and stopping
To start them, run the following from this directory:
docker compose up --wait
To stop them, run:
docker compose down
(Add -v
to delete the data too.)
Connecting
Ports
To connect to the databases, you will need to get the ports.
The primary port can be found by running:
docker compose port postgres-primary 5432
The replica port can be found by running:
docker compose port postgres-replica 5432
Note that these ports may change if you restart the server.
Credentials
The database username is postgres
, and the password is password
, for both the primary and the replica.
Experimenting with the Hasura GraphQL Engine
Run HGE as follows:
cabal run graphql-engine:exe:graphql-engine -- \
--metadata-database-url="postgresql://postgres:password@$(docker compose --project-directory=server/test-manual/postgres-replicas port postgres-primary 5432)" \
serve \
--enable-console \
--console-assets-dir=$PWD/frontend/dist/apps/server-assets-console
Then run the following to get the replica database connection URL, and add it as the "default" data source.
echo "postgresql://postgres:password@$(docker compose --project-directory=server/test-manual/postgres-replicas port postgres-primary 5432)"