I’m trying to sync a KeePassXC database between my Android phone and my Manjaro Linux system. I want full two-way sync of changes, but I don’t want deletions on one device to remove the file on the other. What’s the best way to configure this? Tools like Syncthing seem close, but I’m not sure which folder settings or ignore rules would prevent deletion sync while still keeping both sides updated. Any guidance or examples would help. Thanks!
This is the cost of offline password managers. You can’t do this at a file level, there is no way for a sync protocol to merge changes from two files. I say this having suffered thanks of a couple passwords from this exact scenario.
You either need to exercise diligence in only adding passwords at one place, or run a “real” db-based password manager.
Might be time to self host vaultwarden if you need real DB features like that.
What you’re describing is not a two-way sync then. You’re expecting this to be an actual database, but it’s just a flat file with XML at its core. Here’s the file format specification .
Best you can do is set frontend options to prevent accidental deletions, and keep lots of backups, or put it on a versioning storage backend.
You may want to switch to a different solution if this is your desired use-case.
I don’t think that’s really possible. Why do you want to do this? What problem are you trying to solve?
Having the same file in both systems without the file being deleted on both if I delete it in one.
That’s what backups solve, for important data like a PW DB you should be running daily backups with versioning. Then if anything gets deleted or corrupted you can restore it easily.
Why not use file versioning on either device folder in syncthing to ensure you retain copies of deleted files? The “simple” setting will retain the last 5-10 versions of any file.
I’d also recommend backing up your data outside of the sync service once a day or whatever interval makes sense to you. That way a wayword sync, even with safeguards, cant really destroy the data.
I tried that with my KeePass database and then I ended up with different conflict versions if a device didn’t sync to my server before I updated on another device. Then I ended up with the conflict versions and old versions I had manually resolve. The Android Syncthing app could get auto killed by the Android OS for memory/battery saving, so I had to go back to OneDrive style syncing where the KeePass Android app would internally merge and resolve conflicts. It couldn’t do that using the Syncthing style syncing.
Ok then just use ignoredelete: https://docs.syncthing.net/advanced/folder-ignoredelete.html
Try Syncthing with IgnoreDelete but note that it’s unrecommended. Maybe use Syncthing as an append-only store


