Knowledge Base MCP Server
Manages projects, requirements, and knowledge entries with full-text search via SQLite FTS5. Provides 19 MCP tools for AI assistants to create, update, search, and delete project data.
README
🗄️ Knowledge Base MCP Server
MCP-сервер для управления знаниями и требованиями по проектам с мгновенным полнотекстовым поиском.
🎯 Возможности
| Фича | Описание |
|---|---|
| Проекты | Создание и управление проектами |
| Требования | Требования с приоритетами и статусами |
| Знания | Записи с тегами и полнотекстовым поиском |
| FTS5 | Мгновенный поиск через SQLite FTS5 |
| CLI | Удобный интерфейс командной строки |
| MCP | 19 инструментов для AI-ассистентов |
📦 Установка
# Клонирование
git clone https://github.com/aisho-alex/knowledge_base_mcp.git
cd knowledge_base_mcp
# Создание виртуального окружения
python -m venv venv
source venv/bin/activate # Linux/Mac
# или: venv\Scripts\activate # Windows
# Установка
pip install -e .
🚀 Быстрый старт
1. Инициализация
python -m kb_mcp.cli init
2. Создание проекта
python -m kb_mcp.cli project create "E-Commerce Platform" \
--desc "Платформа электронной коммерции"
Результат:
✅ Project created!
Name: E-Commerce Platform
ID: 3d8e96cc-3e0f-4329-980b-1376dfa8314e
3. Добавление знаний
# С тегами
python -m kb_mcp.cli kb add \
"3d8e96cc-3e0f-4329-980b-1376dfa8314e" \
"OAuth2 Authentication" \
"Flow: Authorization Code Grant. Providers: Google, GitHub." \
--tags auth,security,oauth2
# Без тегов
python -m kb_mcp.cli kb add \
"3d8e96cc-3e0f-4329-980b-1376dfa8314e" \
"API Endpoints" \
"REST API: GET /users, POST /orders, DELETE /products"
4. Поиск
# Поиск по всем сущностям
python -m kb_mcp.cli search "OAuth2"
# Поиск только в знаниях
python -m kb_mcp.cli kb search "API"
# Фильтрация по тегам
python -m kb_mcp.cli kb list --tags auth,security
📋 Справка по командам
Проекты
| Команда | Описание |
|---|---|
project list |
Список всех проектов |
project create <name> |
Создать проект |
project get <id> |
Детали проекта |
project search <query> |
Поиск проектов |
project delete <id> |
Удалить проект |
Требования
| Команда | Описание |
|---|---|
req list <project_id> |
Список требований |
req create <project_id> <title> <content> |
Создать требование |
req get <id> |
Детали требования |
Приоритеты: high, medium, low
python -m kb_mcp.cli req create \
"3d8e96cc-..." \
"Авторизация" \
"Реализовать OAuth2 через Google и GitHub" \
--priority high
Знания (Knowledge)
| Команда | Описание |
|---|---|
kb list |
Все записи (опционально: --project, --tags) |
kb add <project_id> <title> <content> |
Добавить запись |
kb get <id> |
Детали записи |
kb search <query> |
Полнотекстовый поиск |
Опции:
--tags— теги через запятую (например:--tags api,docs)--req— привязать к требованию
Универсальный поиск
python -m kb_mcp.cli search "OAuth2" --limit 20
Ищет по всем проектам, требованиям и знаниям одновременно.
🏗️ Архитектура
┌─────────────────────────────────────────────────────────────┐
│ CLI / MCP │
└──────────────────────────┬──────────────────────────────────┘
│
┌──────────────────────────▼──────────────────────────────────┐
│ Service Layer │
│ ┌────────────┐ ┌────────────┐ ┌────────────────────────┐ │
│ │ Project │ │Requirement │ │ Knowledge │ │
│ │ Service │ │ Service │ │ Service │ │
│ └────────────┘ └────────────┘ └────────────────────────┘ │
└──────────────────────────┬──────────────────────────────────┘
│
┌──────────────────────────▼──────────────────────────────────┐
│ Repository Layer │
│ ┌────────────────────────────────────────────────────────┐ │
│ │ SQLite + FTS5 │ │
│ │ projects │ requirements │ knowledge_entries │ tags │ │
│ └────────────────────────────────────────────────────────┘ │
└─────────────────────────────────────────────────────────────┘
Модель данных
Проект (Project)
│
├── Требование (Requirement)
│ └── title, content, priority, status
│
└── Запись знания (KnowledgeEntry)
└── title, content, tags[], source_url
🔧 MCP Tools
Сервер предоставляет 19 инструментов для интеграции с AI-ассистентами:
Проекты
projects_list— список проектовproject_create— создать проектproject_get— получить проектproject_update— обновить проектproject_delete— удалить проектproject_search— поиск проектов
Требования
requirements_list— список требованийrequirement_create— создать требованиеrequirement_get— получить требованиеrequirement_update— обновить требованиеrequirement_delete— удалить требование
Знания
knowledge_list— список записейknowledge_create— создать записьknowledge_get— получить записьknowledge_update— обновить записьknowledge_delete— удалить записьknowledge_search— полнотекстовый поиск
Утилиты
unified_search— универсальный поискtags_list— список тегов
Подключение к Claude Desktop
Добавьте в claude_desktop_config.json:
{
"mcpServers": {
"kb-mcp": {
"command": "python",
"args": ["-m", "kb_mcp.main"]
}
}
}
📁 Структура проекта
kb-mcp-server/
├── README.md # Этот файл
├── SPEC.md # Техническая спецификация
├── pyproject.toml # Конфигурация Python-пакета
├── .gitignore
├── data/
│ └── kb.db # SQLite база данных
└── src/
└── kb_mcp/
├── __init__.py
├── main.py # Точка входа MCP
├── cli.py # CLI интерфейс
├── config.py # Конфигурация
├── models/ # Pydantic модели
├── db/ # SQLite + FTS5
│ ├── database.py
│ ├── schema.py
│ └── repositories/
├── services/ # Бизнес-логика
└── mcp/
└── tools.py # MCP инструменты
🔍 Примеры использования
Управление требованиями проекта
# Создаём требования
PROJECT_ID="3d8e96cc-..."
python -m kb_mcp.cli req create "$PROJECT_ID" \
"FR-001: Авторизация" \
"Реализовать вход через Google OAuth2" \
--priority high
python -m kb_mcp.cli req create "$PROJECT_ID" \
"FR-002: Каталог товаров" \
"Отображение товаров с пагинацией" \
--priority medium
python -m kb_mcp.cli req create "$PROJECT_ID" \
"FR-003: Корзина" \
"Добавление, удаление, изменение количества товаров" \
--priority high
# Смотрим требования
python -m kb_mcp.cli req list "$PROJECT_ID"
Результат:
Requirements (3)
┏━━━━━━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━┓
┃ Priority ┃ Status ┃ Title ┃
┡━━━━━━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━┩
│ high │ open │ FR-001: Автор │
│ medium │ open │ FR-002: Катало│
│ high │ open │ FR-003: Корзи │
└─────────────┴─────────────┴────────────────┘
Добавление документации
# API документация
python -m kb_mcp.cli kb add "$PROJECT_ID" \
"REST API v2" \
"Base URL: /api/v2
Endpoints:
GET /products - список товаров
GET /products/{id} - товар по ID
POST /orders - создать заказ
GET /users/me - текущий пользователь" \
--tags api,docs,rest
# Техническая заметка
python -m kb_mcp.cli kb add "$PROJECT_ID" \
"Авторизация Google OAuth2" \
"Scopes: openid, email, profile
Endpoints:
Authorization: https://accounts.google.com/o/oauth2/v2/auth
Token: https://oauth2.googleapis.com/token" \
--tags auth,google,oauth2
# Заметка о микросервисах
python -m kb_mcp.cli kb add "$PROJECT_ID" \
"Архитектура микросервисов" \
"Services:
- auth-service: :8001 (OAuth2)
- product-service: :8002
- order-service: :8003
- notification-service: :8004
Message Broker: Redis Streams" \
--tags architecture,microservices
Поиск по тегам
# Все записи с тегом auth
python -m kb_mcp.cli kb list --tags auth
# Записи с несколькими тегами
python -m kb_mcp.cli kb list --tags api,docs
# Все записи проекта
python -m kb_mcp.cli kb list --project "$PROJECT_ID"
⚙️ Конфигурация
Переменные окружения
| Переменная | По умолчанию | Описание |
|---|---|---|
KB_DB_PATH |
data/kb.db |
Путь к базе данных |
KB_DATA_DIR |
data/ |
Директория для данных |
# Пример с кастомным путём
export KB_DB_PATH=/home/user/my_kb.db
python -m kb_mcp.cli init
🛠️ Разработка
# Установка зависимостей для разработки
pip install -e ".[dev]"
# Запуск тестов
pytest tests/
# Проверка кода
ruff check src/
mypy src/
📄 Лицензия
MIT License — используйте свободно!
🤝 Разработка
- Fork репозитория
- Создайте ветку (
git checkout -b feature/amazing-feature) - Commit (
git commit -m 'feat: add amazing feature') - Push (
git push origin feature/amazing-feature) - Open Pull Request
Made with ❤️ for better knowledge management
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.