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 enabling AI agents to access and manipulate ServiceNow data through natural language interactions, allowing users to search for records, update them, and manage scripts.Last updated -9PythonMIT License
- -securityAlicense-qualityA Model Context Protocol server that enables natural language queries to MySQL databases, powered by XiYanSQL text-to-SQL technology.Last updated -114PythonApache 2.0
- -securityAlicense-qualityA Model Context Protocol server that enables AI agents to query Erick Wendel's talks, blog posts, and videos across different platforms using natural language.Last updated -55TypeScriptMIT License
- -securityFlicense-qualityA Model Context Protocol server that enables AI models to interact with MySQL databases through natural language, supporting SQL queries, table creation, and schema exploration.Last updated -2Python