Self-hosted LiveSync
Self-hosted LiveSync is a community-implemented synchronization plugin, available on every obsidian-compatible platform and using CouchDB as the server.
Note:
- Not compatible with official "Obsidian Sync".
Features
- Synchronize vaults very efficiently with less traffic.
- We can synchronize in live, periodic, or on events, as we need.
- Good at conflicted modification.
- Automatic merging for simple conflicts.
- If it cannot be automated, do not worry! we can use a visual conflict resolver.
- Automatic merging for simple conflicts.
- Using OSS solution for the server.
- We do not have to suspect the server side, at least.
- Compatible solutions can be used.
- End-to-end encryption is supported.
- We can synchronize settings, snippets, themes, and plug-ins, via Customization sync(Beta) or Hidden File Sync
- Receive WebClip from obsidian-livesync-webclip
This plug-in might be useful for researchers, engineers, and developers with a need to keep their notes fully self-hosted for security reasons. Or just anyone who would like the peace of mind of knowing that their notes are fully private.
IMPORTANT NOTICE
- Before installing or upgrading this plug-in, please back your vault up.
- Do not enable this plugin with another synchronization solution at the same time (including iCloud and Obsidian Sync).
- Before enabling this plugin, make sure to disable all the other synchronization methods to avoid content corruption or duplication.
- If you want to synchronize with two or more services, do them one by one, and never enable two synchronization methods at the same time.
- This includes not putting your vault inside a cloud-synchronized folder (eg. an iCloud folder or Dropbox folder)
- This is a synchronization plugin. Not a backup solution. Do not rely on this for backup.
How to use
Get your database ready.
First, let us make our database ready. fly.io is preferred for testing. Or you can use your own server with CouchDB.
For more information, refer below:
Configure the plugin
Something looks corrupted...
Please open the configuration link again and Answer below:
- If your local database looks corrupted (in other words, when your Obsidian getting weird even standalone.)
- Answer
No
toKeep local DB?
- Answer
- If your remote database looks corrupted (in other words, when something happens while replicating)
- Answer
No
toKeep remote DB?
- Answer
If you answered No
to both, your databases will be rebuilt by the content on your device. And the remote database will lock out other devices. You have to synchronize all your devices again. (When this time, almost all your files should be synchronized with a timestamp. So you can use an existing vault).
Information in StatusBar
Synchronization status is shown in statusbar.
- Status
- ⏹️ Stopped
- 💤 LiveSync enabled. Waiting for changes
- ⚡️ Synchronization in progress
- ⚠ An error occurred
- Statistical indicator
- ↑ Uploaded chunks and metadata
- ↓ Downloaded chunks and metadata
- Progress indicator
- 📥 Unprocessed transferred items
- 📄 Working database operation
- 💾 Working write storage processes
- ⏳ Working read storage processes
- 🛫 Pending read storage processes
- ⚙️ Working or pending storage processes of hidden files
- 🧩 Waiting chunks
- 🔌 Working Customisation items (Configuration, snippets and plug-ins)
To prevent file and database corruption, please wait until all progress indicators have disappeared. Especially in case of if you have deleted or renamed files.
Hints
- If a folder becomes empty after a replication, it will be deleted by default. But you can toggle this behaviour. Check the Settings.
- LiveSync mode drains more batteries in mobile devices. Periodic sync with some automatic sync is recommended.
- Mobile Obsidian can not connect to non-secure (HTTP) or locally-signed servers, even if the root certificate is installed on the device.
- There are no 'exclude_folders' like configurations.
- While synchronizing, files are compared by their modification time and the older ones will be overwritten by the newer ones. Then plugin checks for conflicts and if a merge is needed, a dialog will open.
- Rarely, a file in the database could be corrupted. The plugin will not write to local storage when a file looks corrupted. If a local version of the file is on your device, the corruption could be fixed by editing the local file and synchronizing it. But if the file does not exist on any of your devices, then it can not be rescued. In this case, you can delete these items from the settings dialog.
- To stop the boot-up sequence (eg. for fixing problems on databases), you can put a
redflag.md
file (or directory) at the root of your vault. Tip for iOS: a redflag directory can be created at the root of the vault using the File application. - Also, with
redflag2.md
placed, we can automatically rebuild both the local and the remote databases during the boot-up sequence. Withredflag3.md
, we can discard only the local database and fetch from the remote again. - Q: The database is growing, how can I shrink it down? A: each of the docs is saved with their past 100 revisions for detecting and resolving conflicts. Picturing that one device has been offline for a while, and comes online again. The device has to compare its notes with the remotely saved ones. If there exists a historic revision in which the note used to be identical, it could be updated safely (like git fast-forward). Even if that is not in revision histories, we only have to check the differences after the revision that both devices commonly have. This is like git's conflict-resolving method. So, We have to make the database again like an enlarged git repo if you want to solve the root of the problem.
- And more technical Information is in the Technical Information
- If you want to synchronize files without obsidian, you can use filesystem-livesync.
- WebClipper is also available on Chrome Web Store:obsidian-livesync-webclip
Repo is here: obsidian-livesync-webclip. (Docs are a work in progress.)
Troubleshooting
If you are having problems getting the plugin working see: Troubleshooting
License
The source code is licensed under the MIT License.