Qdrant MCP Server
официальныйРеализует семантический слой памяти поверх векторного поискового движка Qdrant.
Документация
mcp-server-qdrant: MCP-сервер Qdrant
Model Context Protocol (MCP) — это открытый протокол, обеспечивающий бесшовную интеграцию между LLM-приложениями и внешними источниками данных и инструментами. Независимо от того, создаёте ли вы среду разработки на базе ИИ, улучшаете чат-интерфейс или разрабатываете собственные рабочие процессы с ИИ, MCP предоставляет стандартизированный способ подключения LLM к необходимому им контексту.
Этот репозиторий — пример создания MCP-сервера для Qdrant, векторной поисковой системы.
Обзор
Официальный сервер Model Context Protocol для сохранения и извлечения воспоминаний в векторной поисковой системе Qdrant. Он выступает в роли семантического слоя памяти поверх базы данных Qdrant.
Компоненты
Инструменты
qdrant-store- Сохраняет информацию в базе данных Qdrant
- Входные данные:
information(строка): Информация для сохраненияmetadata(JSON): Необязательные метаданные для сохраненияcollection_name(строка): Имя коллекции для сохранения информации. Это поле обязательно, если не задано имя коллекции по умолчанию. Если имя коллекции по умолчанию задано, это поле не используется.
- Возвращает: Сообщение с подтверждением
qdrant-find- Извлекает релевантную информацию из базы данных Qdrant
- Входные данные:
query(строка): Запрос для поискаcollection_name(строка): Имя коллекции для сохранения информации. Это поле обязательно, если не задано имя коллекции по умолчанию. Если имя коллекции по умолчанию задано, это поле не используется.
- Возвращает: Информацию, сохранённую в базе данных Qdrant, в виде отдельных сообщений
Переменные окружения
Конфигурация задаётся через переменные окружения. Единственный аргумент командной строки — --transport, используемый для выбора транспортного протокола.
[!NOTE] Нельзя одновременно указывать
QDRANT_URLиQDRANT_LOCAL_PATH.
| Имя | Описание | Значение по умолчанию |
|---|---|---|
QDRANT_URL | URL сервера Qdrant | Нет |
QDRANT_API_KEY | API-ключ для сервера Qdrant | Нет |
COLLECTION_NAME | Имя коллекции по умолчанию. | Нет |
QDRANT_LOCAL_PATH | Путь к локальной базе данных Qdrant (альтернатива QDRANT_URL) | Нет |
EMBEDDING_PROVIDER | Используемый провайдер эмбеддингов (пока поддерживается только "fastembed") | fastembed |
EMBEDDING_MODEL | Имя используемой модели эмбеддингов | sentence-transformers/all-MiniLM-L6-v2 |
TOOL_STORE_DESCRIPTION | Пользовательское описание инструмента сохранения | См. значение по умолчанию в settings.py |
TOOL_FIND_DESCRIPTION | Пользовательское описание инструмента поиска | См. значение по умолчанию в settings.py |
QDRANT_SEARCH_LIMIT | Максимальное количество результатов поиска | 10 |
QDRANT_READ_ONLY | Включить режим только для чтения (отключает инструмент qdrant-store) | false |
Переменные окружения FastMCP
Поскольку mcp-server-qdrant основан на FastMCP, он также поддерживает все переменные окружения FastMCP. Наиболее
важные из них перечислены ниже:
| Переменная окружения | Описание | Значение по умолчанию |
|---|---|---|
FASTMCP_LOG_LEVEL | Установить уровень логирования (DEBUG, INFO, WARNING, ERROR, CRITICAL) | INFO |
FASTMCP_SERVER_DEBUG | Включить режим отладки | false |
FASTMCP_SERVER_HOST | Адрес хоста для привязки сервера | 127.0.0.1 |
FASTMCP_SERVER_PORT | Порт для запуска сервера | 8000 |
FASTMCP_SERVER_ON_DUPLICATE_RESOURCES | Поведение при дублировании ресурсов (warn, error, replace, ignore) | warn |
FASTMCP_SERVER_ON_DUPLICATE_TOOLS | Поведение при дублировании инструментов (warn, error, replace, ignore) | warn |
FASTMCP_SERVER_ON_DUPLICATE_PROMPTS | Поведение при дублировании промптов (warn, error, replace, ignore) | warn |
FASTMCP_SERVER_DEPENDENCIES | Список зависимостей для установки в окружении сервера | [] |
[!NOTE] Специфичные для сервера настройки используют префикс
FASTMCP_SERVER_. В будущих версиях это может измениться.
Установка
Использование uvx
При использовании uvx специальная установка для непосредственного запуска mcp-server-qdrant не требуется.
QDRANT_URL="http://localhost:6333" \
COLLECTION_NAME="my-collection" \
EMBEDDING_MODEL="sentence-transformers/all-MiniLM-L6-v2" \
uvx mcp-server-qdrant
Транспортные протоколы
Сервер поддерживает различные транспортные протоколы, которые можно указать с помощью флага --transport:
QDRANT_URL="http://localhost:6333" \
COLLECTION_NAME="my-collection" \
uvx mcp-server-qdrant --transport sse
Поддерживаемые транспортные протоколы:
stdio(по умолчанию): Транспорт через стандартный ввод/вывод, может использоваться только локальными MCP-клиентамиsse: Транспорт Server-Sent Events, идеально подходит для удалённых клиентовstreamable-http: Потоковый HTTP-транспорт, идеально подходит для удалённых клиентов, более современный, чем SSE
Если не указано иное, транспортом по умолчанию является stdio.
При использовании SSE-транспорта сервер будет слушать указанный порт и ожидать входящих подключений. Порт по умолчанию —
8000, однако его можно изменить с помощью переменной окружения FASTMCP_SERVER_PORT.
QDRANT_URL="http://localhost:6333" \
COLLECTION_NAME="my-collection" \
FASTMCP_SERVER_PORT=1234 \
uvx mcp-server-qdrant --transport sse
Использование Docker
Для сборки и запуска MCP-сервера доступен Dockerfile:
# Build the container
docker build -t mcp-server-qdrant .
# Run the container
docker run -p 8000:8000 \
-e FASTMCP_SERVER_HOST="0.0.0.0" \
-e QDRANT_URL="http://your-qdrant-server:6333" \
-e QDRANT_API_KEY="your-api-key" \
-e COLLECTION_NAME="your-collection" \
mcp-server-qdrant
[!TIP] Обратите внимание, что мы устанавливаем
FASTMCP_SERVER_HOST="0.0.0.0", чтобы сервер слушал все сетевые интерфейсы. Это необходимо при запуске сервера в контейнере Docker.
Установка через Smithery
Чтобы установить Qdrant MCP Server для Claude Desktop автоматически через Smithery:
npx @smithery/cli install mcp-server-qdrant --client claude
Ручная настройка Claude Desktop
Чтобы использовать этот сервер с приложением Claude Desktop, добавьте следующую конфигурацию в раздел "mcpServers" вашего
claude_desktop_config.json:
{
"qdrant": {
"command": "uvx",
"args": ["mcp-server-qdrant"],
"env": {
"QDRANT_URL": "https://xyz-example.eu-central.aws.cloud.qdrant.io:6333",
"QDRANT_API_KEY": "your_api_key",
"COLLECTION_NAME": "your-collection-name",
"EMBEDDING_MODEL": "sentence-transformers/all-MiniLM-L6-v2"
}
}
}
Для локального режима Qdrant:
{
"qdrant": {
"command": "uvx",
"args": ["mcp-server-qdrant"],
"env": {
"QDRANT_LOCAL_PATH": "/path/to/qdrant/database",
"COLLECTION_NAME": "your-collection-name",
"EMBEDDING_MODEL": "sentence-transformers/all-MiniLM-L6-v2"
}
}
}
Этот MCP-сервер автоматически создаст коллекцию с указанным именем, если она не существует.
По умолчанию сервер будет использовать модель эмбеддингов sentence-transformers/all-MiniLM-L6-v2 для кодирования воспоминаний.
На данный момент поддерживаются только модели FastEmbed.
Поддержка других инструментов
Этот MCP-сервер можно использовать с любым MCP-совместимым клиентом. Например, его можно использовать с Cursor и VS Code, которые предоставляют встроенную поддержку Model Context Protocol.
Использование с Cursor/Windsurf
Вы можете настроить этот MCP-сервер для работы в качестве инструмента поиска по коду для Cursor или Windsurf, настроив описания инструментов:
QDRANT_URL="http://localhost:6333" \
COLLECTION_NAME="code-snippets" \
TOOL_STORE_DESCRIPTION="Store reusable code snippets for later retrieval. \
The 'information' parameter should contain a natural language description of what the code does, \
while the actual code should be included in the 'metadata' parameter as a 'code' property. \
The value of 'metadata' is a Python dictionary with strings as keys. \
Use this whenever you generate some code snippet." \
TOOL_FIND_DESCRIPTION="Search for relevant code snippets based on natural language descriptions. \
The 'query' parameter should describe what you're looking for, \
and the tool will return the most relevant code snippets. \
Use this when you need to find existing code snippets for reuse or reference." \
uvx mcp-server-qdrant --transport sse # Enable SSE transport
В Cursor/Windsurf вы затем можете настроить MCP-сервер в своих параметрах, указав этот работающий сервер с использованием транспортного протокола SSE. Описание того, как добавить MCP-сервер в Cursor, можно найти в документации Cursor. Если вы запускаете Cursor/Windsurf локально, вы можете использовать следующий URL:
http://localhost:8000/sse
[!TIP] Мы рекомендуем транспорт SSE как предпочтительный способ подключения Cursor/Windsurf к MCP-серверу, поскольку он поддерживает удалённые соединения. Это упрощает совместное использование сервера с командой или его использование в облачной среде.
Эта конфигурация превращает MCP-сервер Qdrant в специализированный инструмент поиска по коду, который может:
- Сохранять фрагменты кода, документацию и детали реализации
- Извлекать релевантные примеры кода на основе семантического поиска
- Помогать разработчикам находить конкретные реализации или шаблоны использования
Вы можете наполнить базу данных, сохраняя описания фрагментов кода на естественном языке (в параметре information)
вместе с самим кодом (в свойстве metadata.code), а затем искать их, используя запросы на естественном языке,
описывающие то, что вы ищете.
[!NOTE] Приведённые выше описания инструментов являются примерами и, возможно, потребуют настройки под ваш конкретный случай использования. Рассмотрите возможность корректировки описаний, чтобы они лучше соответствовали рабочему процессу вашей команды и конкретным типам фрагментов кода, которые вы хотите сохранять и извлекать.
Если вы успешно установили mcp-server-qdrant, но всё ещё не можете заставить его работать с Cursor, пожалуйста,
рассмотрите возможность создания правил Cursor, чтобы MCP-инструменты всегда использовались, когда
агент создаёт новый фрагмент кода. Вы можете ограничить правила так, чтобы они работали только для определённых типов файлов, чтобы избежать использования
MCP-сервера для документации или других типов контента.
Использование с Claude Code
Вы можете расширить возможности Claude Code, подключив его к этому MCP-серверу, что позволит выполнять семантический поиск по вашей существующей кодовой базе.
Настройка mcp-server-qdrant
-
Добавьте MCP-сервер в Claude Code:
# Add mcp-server-qdrant configured for code search claude mcp add code-search \ -e QDRANT_URL="http://localhost:6333" \ -e COLLECTION_NAME="code-repository" \ -e EMBEDDING_MODEL="sentence-transformers/all-MiniLM-L6-v2" \ -e TOOL_STORE_DESCRIPTION="Store code snippets with descriptions. The 'information' parameter should contain a natural language description of what the code does, while the actual code should be included in the 'metadata' parameter as a 'code' property." \ -e TOOL_FIND_DESCRIPTION="Search for relevant code snippets using natural language. The 'query' parameter should describe the functionality you're looking for." \ -- uvx mcp-server-qdrant -
Проверьте, что сервер добавлен:
claude mcp list
Использование семантического поиска по коду в Claude Code
Описания инструментов, указанные в TOOL_STORE_DESCRIPTION и TOOL_FIND_DESCRIPTION, подсказывают Claude Code, как использовать
MCP-сервер. Приведённые выше описания являются примерами и, возможно, потребуют настройки под ваш конкретный случай использования. Однако
Claude Code уже должен уметь:
- Использовать инструмент
qdrant-storeдля сохранения фрагментов кода с описаниями. - Использовать инструмент
qdrant-findдля поиска релевантных фрагментов кода с помощью естественного языка.
Запуск MCP-сервера в режиме разработки
MCP-сервер можно запустить в режиме разработки с помощью команды mcp dev. Это запустит сервер и откроет MCP
инспектор в вашем браузере.
COLLECTION_NAME=mcp-dev fastmcp dev src/mcp_server_qdrant/server.py
Использование с VS Code
Для установки в один клик нажмите одну из кнопок установки ниже:
Ручная установка
Добавьте следующий блок JSON в файл пользовательских настроек (JSON) в VS Code. Это можно сделать, нажав Ctrl + Shift + P и введя Preferences: Open User Settings (JSON).
{
"mcp": {
"inputs": [
{
"type": "promptString",
"id": "qdrantUrl",
"description": "Qdrant URL"
},
{
"type": "promptString",
"id": "qdrantApiKey",
"description": "Qdrant API Key",
"password": true
},
{
"type": "promptString",
"id": "collectionName",
"description": "Collection Name"
}
],
"servers": {
"qdrant": {
"command": "uvx",
"args": ["mcp-server-qdrant"],
"env": {
"QDRANT_URL": "${input:qdrantUrl}",
"QDRANT_API_KEY": "${input:qdrantApiKey}",
"COLLECTION_NAME": "${input:collectionName}"
}
}
}
}
}
Или, если вы предпочитаете использовать Docker, добавьте вместо этого следующую конфигурацию:
{
"mcp": {
"inputs": [
{
"type": "promptString",
"id": "qdrantUrl",
"description": "Qdrant URL"
},
{
"type": "promptString",
"id": "qdrantApiKey",
"description": "Qdrant API Key",
"password": true
},
{
"type": "promptString",
"id": "collectionName",
"description": "Collection Name"
}
],
"servers": {
"qdrant": {
"command": "docker",
"args": [
"run",
"-p", "8000:8000",
"-i",
"--rm",
"-e", "QDRANT_URL",
"-e", "QDRANT_API_KEY",
"-e", "COLLECTION_NAME",
"mcp-server-qdrant"
],
"env": {
"QDRANT_URL": "${input:qdrantUrl}",
"QDRANT_API_KEY": "${input:qdrantApiKey}",
"COLLECTION_NAME": "${input:collectionName}"
}
}
}
}
}
В качестве альтернативы вы можете создать файл .vscode/mcp.json в вашем рабочем пространстве со следующим содержимым:
{
"inputs": [
{
"type": "promptString",
"id": "qdrantUrl",
"description": "Qdrant URL"
},
{
"type": "promptString",
"id": "qdrantApiKey",
"description": "Qdrant API Key",
"password": true
},
{
"type": "promptString",
"id": "collectionName",
"description": "Collection Name"
}
],
"servers": {
"qdrant": {
"command": "uvx",
"args": ["mcp-server-qdrant"],
"env": {
"QDRANT_URL": "${input:qdrantUrl}",
"QDRANT_API_KEY": "${input:qdrantApiKey}",
"COLLECTION_NAME": "${input:collectionName}"
}
}
}
}
Для конфигурации рабочего пространства с Docker используйте это в .vscode/mcp.json:
{
"inputs": [
{
"type": "promptString",
"id": "qdrantUrl",
"description": "Qdrant URL"
},
{
"type": "promptString",
"id": "qdrantApiKey",
"description": "Qdrant API Key",
"password": true
},
{
"type": "promptString",
"id": "collectionName",
"description": "Collection Name"
}
],
"servers": {
"qdrant": {
"command": "docker",
"args": [
"run",
"-p", "8000:8000",
"-i",
"--rm",
"-e", "QDRANT_URL",
"-e", "QDRANT_API_KEY",
"-e", "COLLECTION_NAME",
"mcp-server-qdrant"
],
"env": {
"QDRANT_URL": "${input:qdrantUrl}",
"QDRANT_API_KEY": "${input:qdrantApiKey}",
"COLLECTION_NAME": "${input:collectionName}"
}
}
}
}
Участие в разработке
Если у вас есть предложения по улучшению mcp-server-qdrant или вы хотите сообщить об ошибке, создайте issue! Мы будем рады любым вкладам.
Тестирование mcp-server-qdrant локально
MCP inspector — это инструмент разработчика для тестирования и отладки MCP серверов. Он запускает клиентский UI (порт по умолчанию 5173) и прокси-сервер MCP (порт по умолчанию 3000). Откройте клиентский UI в вашем браузере, чтобы использовать инспектор.
QDRANT_URL=":memory:" COLLECTION_NAME="test" \
fastmcp dev src/mcp_server_qdrant/server.py
После запуска откройте браузер по адресу http://localhost:5173, чтобы получить доступ к интерфейсу инспектора.
Лицензия
Этот MCP-сервер лицензирован под Apache License 2.0. Это означает, что вы можете свободно использовать, изменять и распространять программное обеспечение в соответствии с условиями Apache License 2.0. Для получения дополнительной информации смотрите файл LICENSE в репозитории проекта.