# Протокол синхронизации данных между доверенными ядрами HMP-агента ## 1. Общая идея Пользователь самостоятельно разворачивает несколько доверенных ядер HMP-агента на разных устройствах. Каждое ядро ведёт свою локальную БД знаний и может синхронизироваться с другими ядрами через лёгкий peer-to-peer протокол. Синхронизация осуществляется отдельной утилитой, запускаемой по расписанию или по запросу локального ядра. ## 2. Принципы - **Доверие**: Все ядра считаются доверенными, принадлежат одному пользователю. - **Изоляция**: Ядра разных пользователей не взаимодействуют напрямую — обмен знаниями происходит между независимыми агентами. - **Непрерывность**: Локальное ядро работает автономно, даже без связи с другими. - **Асинхронное разрешение конфликтов**: Конфликты не решаются моментально — вместо этого создаются задачи для агента, и все версии записей распространяются по всем ядрам. ## 3. Механизм синхронизации ### 3.1. Инициация Утилита синхронизации: 1. Устанавливает соединение с другими ядрами (по списку доверенных адресов). 2. Запрашивает: - список записей в БД (по хэшам, ID или timestamp), - список удалённых записей (soft-delete). ### 3.2. Сравнение и обнаружение различий Утилита сравнивает локальные и удалённые данные: #### 3.2.1. Типы различий - Запись **есть у соседа**, но **отсутствует локально** → добавить к себе (если не удалена). - Запись **есть локально**, но **отсутствует у соседа** → отправить (если не удалена). - Запись есть **в обоих ядрах**, но различается содержимое → **конфликт**: - Различие в полях. - Разное состояние удаления. - Разные версии (по содержанию и меткам времени). ### 3.3. Обработка конфликтов 1. Все обнаруженные версии конфликтной записи сохраняются в локальной БД. 2. Опрашиваются другие доступные узлы по поводу значений данной записи в их БД. 3. Создаётся задача агента вида `resolve_conflict(entry_id, versions, metadata, context)`. 4. Эта задача передаётся в очередь задач и может обрабатываться в фоновом режиме, с привлечением LLM или с участием пользователя. 5. Конфликтный набор записей и задача **рассылаются другим ядрам**, чтобы они: - тоже сохранили конфликтные версии, - не принимали преждевременное решение, - были готовы принять финальную `authoritative`-версию после обработки задачи агентом. ### 3.4. Применение решений Когда задача разрешена: - Финальная версия помечается как `authoritative`. - Эта версия синхронизируется со всеми доверенными ядрами. - Старые версии архивируются или удаляются. ## 4. Удаление записей - Удаление всегда начинается с soft-delete (пометка). - Через заданное время (TTL) может быть произведён hard-delete (физическое удаление). - Если при синхронизации найдено расхождение между soft-delete и существующей записью — создаётся конфликт и задача на разрешение. ## 5. Мини-протокол обмена Можно реализовать как API, CLI или TCP-протокол: ```http GET /entries/hash_list # список записей (ID + хэш или timestamp) GET /entry/ # получить полную запись POST /entry/ # отправить/обновить запись GET /deleted_list # список удалённых ID POST /conflict/ # отправка конфликтных версий и задачи ``` ## 6. Заключение Схема позволяет сохранить простоту «одиночного ядра», добавляя лишь синхронизирующую утилиту. Обработка конфликтов вынесена в агента, а не в протокол — это позволяет использовать когнитивные возможности ядра (в т.ч. LLM) для принятия решений, без перегрузки пользователя.