Skip to content

Synchronization

azivner edited this page Sep 11, 2018 · 27 revisions

Trilium supports synchronization with star-shaped topology:

This means that there's one central server (we'll call this instance sync server) and several client (sometimes called desktop) instances which all point to this sync server and synchronize against it.

Once sync is setup, synchronization is automatic and ongoing - you don't need to trigger it manually. It should "just work".

How to setup synchronization

Setup synchronization from desktop instance to sync server

This approach is used when you already have a desktop instance of Trilium and you want to setup sync server on your web host.

So let's assume your server instance is already setup. Then open your desktop instance, click on Options -> Sync tab -> Sync configuration and set "Server instance address" to point to your sync server. Click Save.

Now click on "Test sync" button which will tell you if the handshake with sync server succeeded. If yes, sync with sync server started and might take some time to finish, but you can close the Options dialog and keep using Trilium.

You can also check the server instance periodically to see if the sync finished. Once it's finished you should see login screen.

Setup synchronization from sync server do desktop instance

This is used when you already have sync server and you want to setup desktop instance to sync with (from) it.

Here we assume that you downloaded the most recent release for your platform, unzipped it and ran it.

Since the desktop instance is completely empty, it will first ask if you want to create initial document or you want to setup sync with sync server - you need to choose the second option.

You'll need to configure Trilium server address and importantly also correct username / password (sync setup requires authentication).

Click on "Finish setup" button and if everything went fine, you'll see this screen:

Once the sync is finished, you'll be automatically redirected to the Trilium application.

Conflict resolution

You can sometimes encounter a situation where you edit same note in multiple instances before the note changes are synchronized.

Trilium handles this situation by just picking up the newer change and discarding the older change. The older change should still be visible in note revisions so it should be possible to recover any data lost in conflict resolution.

Hash check

After each completed sync, Trilium computes hash of all synced data on both client and sync server. If there's a difference, something went wrong and Trilium will notify you about this.

Clone this wiki locally