S3 MCP-сервер
Сервер Amazon S3 Model Context Protocol (MCP), предоставляющий инструменты для взаимодействия с контейнерами и объектами S3.
https://github.com/user-attachments/assets/d05ff0f1-e2bf-43b9-8d0c-82605abfb666
Обзор
Этот сервер MCP позволяет большим языковым моделям (LLM), таким как Claude, взаимодействовать с хранилищем AWS S3. Он предоставляет инструменты для:
Список доступных S3-корзин
Перечисление объектов в контейнере
Извлечение содержимого объекта
Сервер создан с использованием TypeScript и MCP SDK, что обеспечивает безопасный и стандартизированный способ взаимодействия LLM с S3.
Related MCP server: AWS MCP Server
Установка
Предпосылки
Node.js 18 или выше
npm или пряжа
Настроенные учетные данные AWS (через переменные среды или файл учетных данных AWS)
Docker (опционально, для контейнерной установки)
Настраивать
Установить через npm:
Если сборка из исходного кода:
Настройте учетные данные AWS и доступ к S3:
Создайте файл .env с вашей конфигурацией AWS:
Или установите их как переменные среды.
Конфигурация
Сервер можно настроить с помощью следующих переменных среды:
Переменная | Описание | По умолчанию |
| Регион AWS, где расположены ваши контейнеры S3 |
|
| Список разрешенных имен контейнеров S3, разделенных запятыми | (пустой) |
| Максимальное количество сегментов для возврата в листинге |
|
| Ключ доступа AWS (если не используются учетные данные по умолчанию) | (из конфигурации AWS) |
| Секретный ключ AWS (если не используются учетные данные по умолчанию) | (из конфигурации AWS) |
Запуск сервера
Прямое выполнение Node.js
Вы можете запустить сервер напрямую с Node.js:
Настройка Docker 🐳
Вы можете запустить сервер S3 MCP как контейнер Docker, используя Docker CLI или Docker Compose.
Использование Docker CLI
Создайте образ Docker:
Запустите контейнер с переменными среды:
Проверьте журналы контейнера:
Остановитесь и удалите контейнер:
Обратите внимание, что контейнер не предоставляет никаких портов, поскольку он предназначен для использования с Claude Desktop через Docker exec, а не через прямые HTTP-соединения.
Использование Docker Compose
Соберите и запустите Docker-контейнер:
Чтобы остановить контейнер:
Использование Docker с MinIO для тестирования
Настройка Docker Compose включает службу MinIO для локального тестирования:
Служба MinIO автоматически создает два тестовых контейнера ( test-bucket-1 и test-bucket-2 ) и загружает файлы образцов для тестирования.
Отладка в MCP Inspector
Для отладки сервера с помощью MCP Inspector:
При использовании опции --docker-compose скрипт выполнит следующие действия:
Запустите контейнеры MinIO и сервера S3 MCP, если они не запущены.
Запустите MCP Inspector, подключенный к серверу S3 MCP.
Затем вы можете протестировать инструменты S3 на локальном экземпляре MinIO.
Подключение к Claude Desktop
Чтобы использовать этот сервер с Claude Desktop:
Отредактируйте файл конфигурации Claude Desktop:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
Добавьте сервер S3 MCP в конфигурацию:
Вариант Docker для Claude Desktop 🐳
Вы также можете настроить Claude Desktop для использования работающего контейнера Docker для сервера MCP:
⚠️ Важные предварительные условия : для работы этой конфигурации Docker вам СЛЕДУЕТ сначала собрать и запустить контейнер Docker ПЕРЕД запуском Claude Desktop:
# 1. First, build the Docker image (only needed once or after changes) docker build -t aws-s3-mcp . # 2. Then start the container (required each time before using with Claude) # Using Docker Compose (recommended) docker compose up -d s3-mcp # Or using Docker CLI docker run -d --name aws-s3-mcp-server --env-file .env aws-s3-mcpБез запущенного контейнера Claude Desktop будет выдавать ошибки при попытке использования инструментов S3.
Конфигурация Docker выше использует
execдля отправки запросов MCP напрямую в работающий контейнер. Сопоставление портов не требуется, поскольку Claude взаимодействует с контейнером напрямую, а не через сетевой порт.
Примечание : убедитесь, что имя контейнера в конфигурации (
aws-s3-mcp-server) совпадает с именем запущенного контейнера.
Важно : при использовании указанной выше конфигурации обратите внимание на следующее:
Замените
AWS_ACCESS_KEY_IDиAWS_SECRET_ACCESS_KEYна ваши фактические учетные данные.
S3_BUCKETSдолжен содержать список контейнеров, разделенных запятыми, к которым вы хотите разрешить доступ.
AWS_REGIONдолжен быть установлен на регион, где расположены ваши контейнеры.
💣 Если возникла ошибка на Claude Desktop
Если вы столкнулись с ошибками в приведенной выше конфигурации в Claude Desktop, попробуйте использовать абсолютные пути следующим образом:
Доступные инструменты
список-ведра
Перечисляет доступные S3-корзины, к которым у сервера есть разрешение на доступ. Этот инструмент учитывает конфигурацию S3_BUCKETS , которая ограничивает отображаемые корзинки.
Параметры: Нет
Пример вывода:
список-объектов
Перечисляет объекты в указанном контейнере S3.
Параметры:
bucket(обязательно): Имя корзины S3, из которой нужно получить список объектов.prefix(необязательно): префикс для фильтрации объектов (например, путь к папке)maxKeys(необязательно): максимальное количество возвращаемых объектов.
Пример вывода:
получить-объект
Извлекает объект из указанного контейнера S3. Текстовые файлы возвращаются как обычный текст, а двоичные файлы возвращаются с ограниченными подробностями.
Параметры:
bucket(обязательно): Имя ведра S3key(обязательно): Ключ (путь) объекта для извлечения
Пример текстового вывода:
Пример двоичного вывода:
Соображения безопасности
Сервер будет иметь доступ только к тем контейнерам, которые указаны в переменной среды
S3_BUCKETS.Учетные данные AWS должны иметь соответствующие разрешения для корзин
Используйте принцип наименьших привилегий при настройке разрешений AWS.
Для использования в производственной среде рассмотрите возможность использования ролей IAM с определенными разрешениями S3.
Использование с Клодом
При взаимодействии с Клодом в настольном приложении вы можете попросить его выполнить такие операции S3, как:
«Список всех моих S3-корзин»
«Обобщить файлы PDF в корзине my-documents»
"Получить файл README.txt из my-documents-bucket"
Клод воспользуется соответствующим инструментом MCP для выполнения запроса и покажет вам результаты.
Лицензия
Массачусетский технологический институт