MCP-сервер BlazeSQL
Этот проект реализует сервер Model Context Protocol (MCP) с использованием @modelcontextprotocol/sdk
, который действует как прокси для API BlazeSQL Natural Language Query. Он позволяет MCP-совместимым клиентам (например, Cursor, Claude 3 с использованием инструмента, MCP Inspector и т. д.) взаимодействовать с BlazeSQL с использованием естественного языка.
Функции
- Создан с использованием современного вспомогательного класса
McpServer
из MCP SDK. - Предоставляет API запросов на естественном языке BlazeSQL как инструмент MCP с именем
blazesql_query
. - Использует
zod
для надежной проверки входных параметров инструмента. - Обеспечивает безопасную аутентификацию API-ключа с помощью переменных среды.
- Взаимодействует с клиентами, используя стандартный транспорт MCP stdio.
Диаграмма рабочего процесса
На этой диаграмме показана последовательность взаимодействий, когда клиент использует инструмент blazesql_query
(Примечание: внутренняя логика сервера теперь использует McpServer
, что упрощает регистрацию инструмента по сравнению с низкоуровневыми обработчиками, показанными на диаграмме):
Предпосылки
- Node.js (рекомендуется версия LTS)
- Пряжа (классическая или ягодная)
- Учетная запись BlazeSQL с ключом API (для API требуется подписка Team Advanced).
- В вашей учетной записи BlazeSQL настроено как минимум одно подключение к базе данных.
- Документация API запросов на естественном языке BlazeSQL: https://help.blazesql.com/en/article/natural-language-query-api-1fgx4au/
Настраивать
- Клонировать репозиторий:
- Установить зависимости:Это установит все необходимые зависимости, включая
@modelcontextprotocol/sdk
,dotenv
иzod
. - Настройте переменные среды:
- Скопируйте пример файла среды:
- Отредактируйте файл
.env
:ЗаменитеYOUR_BLAZESQL_API_KEY_HERE
на ваш фактический ключ API, полученный из настроек вашей учетной записи BlazeSQL.
- Скопируйте пример файла среды:
Запуск сервера
- Сборка сервера: Скомпилируйте код TypeScript в JavaScript:
- Запустите сервер: Выполните скомпилированный код:Сервер запустится и запишет сообщения в
stderr
(вы можете увидеть «API Key загружен успешно...» и т. д.). Теперь он прослушивает клиентское соединение MCP через стандартный ввод/вывод (stdio).
Подключение MCP-клиента
Этот сервер использует механизм транспорта stdio .
Использование MCP Inspector (рекомендуется для тестирования)
- Убедитесь, что сервер еще не запущен отдельно.
- Запустите Inspector и дайте ему команду запустить ваш сервер:
- Запустится пользовательский интерфейс Inspector, который автоматически подключится к вашему серверу.
- Перейдите на вкладку «Инструменты», чтобы взаимодействовать с инструментом
blazesql_query
.
Использование интегрированных клиентов (Cursor, Claude 3 и т. д.)
- Запустите сервер в терминале:
- Настройте клиент: в настройках вашего клиента MCP вам необходимо добавить пользовательскую конфигурацию сервера.
- Транспорт: Выберите
stdio
. - Команда: Укажите точную команду, используемую для запуска сервера. Вам необходимо указать абсолютный путь к узлу и абсолютный путь к файлу
build/index.js
.- Пример (macOS/Linux — при необходимости измените пути):
/usr/local/bin/node /Users/your_username/path/to/blaze-sql-mcp-server/build/index.js
- Путь к узлу можно найти, используя
which node
в вашем терминале. - Путь к проекту можно найти с помощью
pwd
внутри каталога проекта.
- Пример (macOS/Linux — при необходимости измените пути):
- Сохраните конфигурацию.
- Транспорт: Выберите
- Теперь клиент сможет подключиться к локально работающему серверу и просмотреть/использовать его инструменты.
Использование инструмента blazesql_query
После подключения клиент может вызвать инструмент blazesql_query
.
- Имя инструмента:
blazesql_query
- Аргументы:
db_id
(string, required): Идентификатор целевого подключения к базе данных в вашей учетной записи BlazeSQL. Вы можете найти этот идентификатор в веб-приложении BlazeSQL при управлении подключениями к базе данных.natural_language_request
(string, required): Запрос, который вы хотите выполнить, написанный на простом английском языке (например, «покажите мне общее количество пользователей»). (Входные данные проверяются с помощьюzod
)
- Пример вызова (с использованием синтаксиса
mcp test
для иллюстрации): - Вывод: в случае успеха инструмент возвращает один блок
text
содержимого, содержащий:- Ответ на естественном языке от агента BlazeSQL.
- Сгенерированный SQL-запрос внутри кода Markdown (
sql ...
). - Результаты данных форматируются как JSON в коде Markdown (
json ...
).
Пример структуры внутри
text
блока:Результат данных (JSON):
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Tools
Сервер Model Context Protocol, который позволяет клиентам ИИ взаимодействовать с API запросов на естественном языке BlazeSQL, позволяя выполнять запросы на естественном языке к базам данных SQL.
Related MCP Servers
- -securityAlicense-qualityA Model Context Protocol server that enables secure and structured interaction with Microsoft SQL Server databases, allowing AI assistants to list tables, read data, and execute SQL queries with controlled access.Last updated -43PythonMIT License
- AsecurityAlicenseAqualityA Model Context Protocol server that enables AI models to interact with MySQL databases, providing tools for querying, executing statements, listing tables, and describing table structures.Last updated -5922MIT License
- AsecurityFlicenseAqualityA Model Context Protocol server that enables AI models to interact with MySQL databases through a standardized interface, providing tools for querying, executing commands, and managing database schemas.Last updated -7JavaScript
- -securityAlicense-qualityA Model Context Protocol server implementation that enables AI assistants to execute SQL queries and interact with SQLite databases through a structured interface.Last updated -7TypeScriptMIT License