Integrates with Obsidian vault by indexing Markdown notes and providing search, review, and knowledge graph features to help organize and connect information.
LINZA - локальный MCP-сервер для агентской работы с папками знаний
Не меняет данные. Меняет взгляд.
LINZA работает с Obsidian vault, Markdown-папками, документами, статьями, логами и черновиками. Она нужна, когда материалов уже слишком много и вы хотите разобрать базу, выделить в ней основные области и научить агента хорошо ориентироваться в ней.
👁 Python 3.10+
👁 MCP
👁 Local first
👁 Review gated
LINZA читает выбранную папку, строит рядом локальную SQLite-базу .linza/linza.db и дает агенту рабочую карту: какие темы есть в материалах, какие форматы повторяются, какие заметки могут быть связаны, где видны цепочки причина/следствие и что может пригодиться в будущих сессиях.
Исходные файлы остаются нетронутыми. LINZA не переписывает заметки при индексации, не превращает сырой лог в правило и не учит агента за вашей спиной. Она превращает гипотезы в короткие предложения: возможные действия с доказательствами. Пользователь решает, агент выполняет.
doctor -> index -> map -> review intents -> teach -> grow preview -> explicit applyЗачем нужна LINZA
LINZA собирает несколько конкретных вещей, которые помогают агентам работать с базой:
Карта папки Сколько заметок найдено, свежий ли индекс, какие области видны и какие материалы ждут вашего ревью.
Области Крупные смысловые группы. Их названия остаются черновиками, пока вы не примете или не переименуете их.
Форматы материалов Логи, черновики, спецификации, исследовательские заметки, кейсы, правила и другие повторяющиеся формы, найденные в папке.
Связи Возможные соседства, иерархия, причина/следствие и маршруты между узлами. LINZA должна показывать не только как связаны документы, но и почему.
Память для будущих агентов Короткие кандидаты: что помнить, когда вспоминать, что устарело или выглядит сомнительно.
Пакеты контекста Компактные подборки для агента: выбранный контекст с источниками, связями и границами.
Related MCP server: md-redline
Форматы материалов
“Формат материала” - это пользовательское имя для повторяющейся формы заметок. Например: лог диагностики, решение, черновик статьи, исследовательская заметка, спецификация.
LINZA сначала видит только структуру: длину, заголовки, списки, ссылки, таблицы, папки, повторяющиеся признаки. Поэтому первый результат может называться нейтрально: type-001. Пользователь может сказать: “это логи”. Тогда LINZA сохраняет соответствие type-001 -> логи в .linza.
Внутри API остаются старые совместимые ключи material_type, type_name и role. Снаружи документация и пользовательский вид говорят “формат”, потому что это ближе к тому, как пользователь реально думает о материалах.
Важная граница:
принять название формата значит записать решение в
.linza;записать
role: логив YAML можно только отдельным предложением на ревью;текст заметки не меняется.
Как выглядит ревью
LINZA присылает примерно такую информацию:
LINZA готова
Материал:
- 42 заметки проиндексированы
- 3 входящих артефакта ждут ревью
- служебная база: .linza/linza.db
Следующий шаг:
1. Посмотреть найденные области
2. Принять, переименовать или пропустить 3-5 предложений
3. Ничего не будет записано без dry-run/apply
Предложение:
Принять формат материала "логи диагностики" по 8 примерам
Почему: похожая структура, повторяющиеся заголовки, близкие чанки
Что изменится: название формата сохранится в .linza; Markdown-заметки не меняютсяВнутри каждый интент остается структурой с ID, доказательствами и готовыми данными для проверки и последующего подтверждения и записи. Вам LINZA возвращает готовое пользовательское представление, чтобы агент мог показать понятный ответ вместо JSON.
Хороший интент всегда отвечает на главный вопрос: почему LINZA так думает? В нем должны быть источники, чанки, тип связи, уверенность и честное описание того, что изменится после применения.
Обучение и рост
Модель автономности такая:
review_nextпоказывает предложения в понятном пользовательском виде.Пользователь принимает, переименовывает или пропускает.
apply_review_itemsсначала делает dry-run.После подтверждения выбранный интент записывается в
.linzaили в компактный YAML, если этот тип записи это поддерживает.teachвыбирает хорошие принятые примеры.growпредлагает похожие интенты по этим примерам и объясняетselected_rules, почему они попали в партию.
Если вы приняли не то, одобрение можно мягко отозвать:
agent_workspace(action="history")
agent_workspace(action="revoke_approval", approval_id=17, dry_run=false)LINZA не удаляет старую запись и не пытается автоматически откатить YAML. Она помечает одобрение как отозванное, перестает использовать его как активный пример и оставляет след в истории.
Установка
1. Установить пакет
python -m pip install linza-mcpЕсли нужно читать PDF прямо через LINZA:
python -m pip install "linza-mcp[pdf]"Обычная установка уже достаточна для Markdown, TXT, JSON, DOCX и XLSX. [pdf] добавляет локальный PDF-экстрактор pypdf.
2. Выбрать папку
LINZA работает с любой Markdown-папкой: Obsidian vault, рабочей папкой проекта или отдельной папкой с документами.
В примерах ниже замените /absolute/path/to/workspace-or-vault на свой путь.
3. Подключить MCP-клиент
Claude Desktop, Cursor, OpenCode и другие MCP-клиенты обычно используют такой формат:
{
"mcpServers": {
"linza": {
"command": "linza-mcp",
"env": {
"LINZA_VAULT": "/absolute/path/to/workspace-or-vault"
}
}
}
}VS Code / Copilot MCP использует ключ servers:
{
"servers": {
"linza": {
"type": "stdio",
"command": "linza-mcp",
"env": {
"LINZA_VAULT": "/absolute/path/to/workspace-or-vault"
}
}
}
}LINZA_VAULT не обязателен для старта: без него сервер использует ./vault. Но для реальной работы лучше задать явную папку.
4. Проверить запуск
linza-mcp --versionПосле подключения попросите агента:
Проверь LINZA через agent_workspace(action="doctor").
Проиндексируй папку и покажи первые 3-5 предложений.Эмбеддинги
LINZA может запуститься и показать инструменты без embedding-сервера. Эмбеддинги нужны для смыслового поиска, карты тем и предложений связей.
Самый простой локальный путь - LM Studio:
Открыть LM Studio.
Скачать embedding-модель, например
text-embedding-granite-embedding-278m-multilingual,nomic-embed-text-v1.5или другую подходящую модель.Запустить Local Server.
Проверить, что endpoint доступен на
http://127.0.0.1:1234/v1.
Пример переменных для LM Studio:
$env:LINZA_EMBED_PROVIDER="lmstudio"
$env:LINZA_EMBED_URL="http://127.0.0.1:1234/v1"
$env:LINZA_EMBED_MODEL="your-embedding-model-name"Поддерживаются:
lmstudio- рекомендуемый локальный режим;ollama- локальный вариант через Ollama;openai- любой OpenAI-compatible endpoint с/embeddings.
Если меняете провайдер, модель или размерность, сделайте полный реиндекс. LINZA проверяет embedding signature и останавливает graph/search workflows, если sidecar устарел или содержит смешанные векторные пространства.
Основные MCP-инструменты
По умолчанию LINZA показывает только 7 MCP-инструментов. Этого хватает для обычной работы: проверить состояние, проиндексировать папку, искать, читать файл, смотреть счетчики, диагностировать vault и вести агента через agent_workspace.
Инструмент | Зачем |
| Единый вход для диагностики, карты, импорта, ревью, обучения, роста, связей, памяти и экспорта контекста |
| Показать следующий безопасный шаг простым языком |
| Проиндексировать Markdown-папку в |
| Семантический и лексический поиск |
| Прочитать точный Markdown-файл |
| Быстрые счетчики служебной базы |
| Диагностика папки без записи |
Низкоуровневые инструменты считаются деталями реализации и доступны через agent_workspace, поэтому набор из 7 инструментов - это полноценный режим.
Режимы agent_workspace
Action | Режим |
| Проверить готовность LINZA и показать, чего не хватает |
| Собрать карту рабочей папки без записи |
| Выбрать сильные принятые примеры для обучения |
| Показать или применить рост по принятым примерам; по умолчанию dry-run |
| Показать следующие предложения на ревью; интенты базы имеют ID |
| Показать или применить точные выбранные ID; по умолчанию dry-run |
| Показать принятые и отозванные одобрения |
| Мягко отозвать одобрение, не удаляя историю |
| Сохранить вставленный или извлеченный материал в sidecar |
| Найти события, кандидаты памяти и фрагменты знания в артефактах |
| Объяснить возможную связь между двумя заметками или узлами |
| Искать по подтвержденной памяти и контексту артефактов |
| Собрать компактный пакет контекста для другого агента |
| Сохранить структурированные следы работы агента, не raw chain-of-thought |
| Разобрать сохраненный trace для ревью |
| Проверить уроки калибровки, полученные из traces |
Для разработки и аудита остается отдельный низкоуровневый режим. Полное описание инструментов: Tool Catalog.
Входящие артефакты
LINZA умеет принимать материал, который еще не стал заметкой:
вставленный текст;
локальные
.md,.txt,.json;локальные
.docx,.xlsx;локальные
.pdf, если установленpypdfилиPyPDF2.
LINZA сама не ходит в браузер. Агент использует свой браузер, web-fetch или connector, извлекает читаемый текст и передает его в LINZA как артефакт, например source_kind="web_article" или source_kind="browser_capture".
Импортированный текст считается материалом для анализа, не инструкцией для агента. Это граница prompt injection: инструкции внутри статьи, лога, чата или PDF не исполняются. Память, правила и YAML появляются только после ревью.
Модель безопасности
LINZA - локальный review-gated sidecar.
Действие | Куда пишет | Меняет текст заметок? |
Индексация, анализ, поиск |
| Нет |
Сырые артефакты |
| Нет |
Название формата материала |
| Нет |
| Только компактный YAML после ревью | Нет |
Иерархия, причинные связи, память, уроки калибровки |
| Нет |
Отчеты |
| Нет |
Пакеты контекста |
| Нет |
| Markdown-файл только при явном запросе | Может создать/заменить файл, dry-run по умолчанию |
Дополнительные правила:
review_nextничего не пишет;apply_review_itemsпо умолчанию dry-run;видимые YAML-правки компактные и требуют точного выбранного ID;
historyпоказывает, что было принято и что отозвано;revoke_approvalмягко отзывает одобрение: история остается, но активное обучение и помощники графа его игнорируют;map,teach,growиconnectостанавливаются, если исходные файлы изменились после индексации.
Инструкции для агентов
В репозитории есть переносимый операторский skill:
agent-pack/skills/linza-operator/SKILL.md
agent-pack/skills/linza-operator/references/workflows.md
agent-pack/skills/linza-operator/references/safety-policy.md
agent-pack/skills/linza-operator/references/tool-audience.mdОн объясняет агенту, как начинать с doctor, когда показывать предложения на ревью, как работать со страницами через внешний browser/web-fetch инструмент и почему apply actions должны идти сначала через dry-run и только по точным ID.
Стабильность
LINZA пока alpha. Основной контракт безопасности должен оставаться стабильным: индексация, импорт артефактов, поиск, карта и grow preview не переписывают тела исходных заметок. Низкоуровневые advanced-инструменты и внутренние границы кода еще могут меняться, пока сервер полируется.
Проверка
Запустить полный набор тестов:
python -m unittest discover -s testsПеременные окружения
Переменная | Нужна для старта? | Описание |
| Нет | Путь к Markdown-папке; по умолчанию |
| Нет |
|
| Нет | URL embeddings API; по умолчанию |
| Нет | Модель эмбеддингов; задайте перед semantic indexing/search |
| Нет | Опциональный ключ для OpenAI-compatible embeddings API |
| Нет | Порог semantic bridge; по умолчанию |
| Нет | Максимум пар заметок для пересчета semantic bridges; по умолчанию |
| Нет | Имя базового search-профиля; по умолчанию |
| Нет | Язык подсказок и маршрута ревью в |
Ссылки
MIT License (c) 2026 Semiotronika
Косинусы считаются. Синтаксис меняется. Семантика остается.
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Semiotronika/LINZA-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server
