Sync MySQL with SQLite

Avoid the complexities of using APIs to move app state over the network. Get super-fast, always-available offline-first/local-first apps.

MySQL
In-app SQLite
PowerSync’s MySQL connector is currently in an alpha release.

Add real-time sync to MySQL

PowerSync streams MySQL changes to clients in real-time, so apps can query and mutate local SQLite without waiting on the network.

Sync Rules handle partial syncing under the hood, giving every user just the data they need.
Backend
PowerSync Service
Clients
MySQL
binlog
replication
Sync Rules
WebSocket or
HTTP 
stream
SQLite
SQLite
MYSQL DATABASE, meet SQLite

How data syncs from MySQL to in-app SQLite

Privilege-scoped connection

PowerSync connects to your MySQL database over TCP with read access to all synced tables and permissions to read binary logs (binlogs).

Replication via binlogs

After an initial snapshot of data is taken, PowerSync subscribes to the binlog stream to capture row-level changes.

Low maintenance

PowerSync automatically handles most schema change scenarios in MySQL, with no need for client-side migrations.

MySQL
Binlog
Table and row filtering

PowerSync filters the binlog stream based on configured Sync Rules to sync only the relevant tables and rows.

Binlog events
Operations history tracked

The PowerSync Service tracks changes to data in the buckets, allowing for efficient delta syncing to clients.

PowerSync Service
Sync Rules
Sync Rules for partial replication

You define Sync Rules which determine which data is synced to which users. Data is grouped into buckets which can be shared between users to avoid duplication.

WebSocket or HTTP stream
Authentication using JWTs

Clients authenticate against the PowerSync Service using JWTs.

Real-time sync

The client SDK initially downloads all relevant data and then incrementally keeps it updated, in real time.

Offline-first, including local writes

Writes are immediately applied locally, and queued for upload to your backend API. The PowerSync client SDK automatically handles failures and retries.

PowerSync Client SDK
In-app SQLite
App data tables
Upload queue
Full database on the client-side

On the client, data is persisted to a SQLite database in schemaless format. The application defines a client-side schema which is applied as SQLite views.

Reactive queries

Live reactive queries can be used to update the UI when data changes.

Strong consistency guarantees

PowerSync uses a server-authoritative architecture with a checkpoint system to guarantee consistency.

Control over the write path

Your backend accepts uploaded writes and then applies them to your Postgres database.

Backend API
MySQL
Binlog
Binlog events
PowerSync Service
Sync Rules
WebSocket or HTTP stream
PowerSync Client SDK
In-app SQLite
App data tables
Upload queue
Backend API
See installation instructions:
Source database setup

Highly scalable and enterprise-ready

Horizontally scalable

AWS VPC Endpoints available in Cloud

Sharded database support

Coming soon
See pricing

Implement MySQL & SQLite sync today

Self-hosted PowerSync
Self-host PowerSync