Syncthing


Syncthing — приложение, позволяющее синхронизировать файлы между несколькими устройствами. Присутствует поддержка сохранения последовательных версий файла по нескольким алгоритмам, включая пользовательский[5], что позволяет использовать Syncthing также для целей резервного копирования, хотя это и не рекомендуется[6]. Приложение и протокол публикуются под открытой лицензией.

Syncthing может работать в локальной сети и сети интернет, передача всех данных происходит по защищенным каналам TLS с использованием протокола обмена ключами с совершенной прямой секретностью, чтобы исключить возможность прослушивания.[7] Синхронизация происходит по дате изменения файла, есть поддержка синхронизации на уровне блоков, то есть при небольших изменениях в файле будут синхронизированы только изменившиеся блоки, а не весь файл.[8]

Syncthing заменяет распространённые закрытые сервисы облачного хранения и синхронизации файлов чем-то более открытым, заслуживающим доверия и децентрализованным. Ваши данные — только ваши и вы заслуживаете выбирать, где они хранятся, доступны ли они третьей стороне и как именно они пересылаются через Интернет.

Для обмена данными между устройствами Syncthing использует специально разработанный Block Exchange Protocol (протокол обмена блоками). Протокол используется между двумя или более узлами сети, которые образуют кластер. Каждый узел имеет один или несколько репозиториев файлов, описанных локальной моделью, которая содержит метаданные и хэши блоков. Локальная модель распространяется между всеми узлами в кластере. Объединение всех локальных моделей формирует глобальную модель, включающую в себя наиболее изменённые версии файлов. Каждый узел стремится синхронизировать локальное хранилище с глобальной моделью, запрашивая у других узлов в кластере отсутствующие или обновившиеся блоки.[8]