PowerSync Service Setup
Configuration details for connecting the PowerSync Service to your database
After configuring your Postgres database for PowerSync, you'll setup your PowerSync Service.
This entails:
Configuring MongoDB (if required)
Defining your PowerSync config
Defining connections to Postgres and MongoDB
Defining your Sync Rules
Defining your auth method
Examples of the above can be found in our demo application here. Below we go through these in more detail.
Configure MongoDB
The PowerSync Service uses MongoDB under the hood and requires at least one replica set node. A single node is fine for development/staging environments, but a 3-node replicas set is recommended for production.
MongoDB Atlas enables replica sets by default for new clusters.
However, if you're using your own environment you can enable this manually by running:
If you are rolling your own , you can include this init script in your docker-compose file to configure a replica set as once-off operation:
PowerSync Configuration
The PowerSync Service is configured using key/value pairs in a config file, and supports the following configuration methods:
Inject config as an environment variable (which contains the of a config file)
Use a config file mounted on a volume
Specify the config as a command line parameter (again )
Both YAML and JSON config files are supported, and you can see examples of the above configuration methods in our demo app's docker-compose file.
A detailed config.yaml
example with additional comments can be found here:
The config file schema is also available here:
Below is a skeleton config file that you can copy/paste and edit locally:
Specify the connection to Postgres in the replication
section. Retrieving your database connection string / individual parameters differs by database hosting provider. See Database Connection for further details.
If you are using hosted Supabase, you will need to enable IPv6 for Docker as per https://docs.docker.com/config/daemon/ipv6/
If your host OS does not support Docker IPv6 e.g. macOS, you will need to run Supabase locally.
This is because Supabase only allows direct database connections over IPv6 — PowerSync cannot connect using the connection pooler.
Specify the connection to MongoDB in the storage
section.
Sync Rules
Your project's sync rules can either be specified within your configuration file directly, or in a separate file that is referenced.
We recommend starting with syncing a single table in a global bucket. Choose a table and sync it by adding the following to your sync rules:
For more information about sync rules see:
Sync RulesCheckpoint
To verify that your sync rules are functioning correctly, inspect the contents of your sync bucket in MongoDB.
If you are running MongoDB in Docker, run the following:
Last updated