Integrations
Provides tools for listing available S3 buckets, listing objects within a bucket, and retrieving object contents from AWS S3 storage.
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.
Установка
Предпосылки
- Node.js 18 или выше
- npm или пряжа
- Настроенные учетные данные AWS (через переменные среды или файл учетных данных AWS)
- Docker (опционально, для контейнерной установки)
Настраивать
- Установить через npm:
- Если сборка из исходного кода:
- Настройте учетные данные AWS и доступ к S3:
Создайте файл .env
с вашей конфигурацией AWS:
Или установите их как переменные среды.
Конфигурация
Сервер можно настроить с помощью следующих переменных среды:
Переменная | Описание | По умолчанию |
---|---|---|
AWS_REGION | Регион AWS, где расположены ваши контейнеры S3 | us-east-1 |
S3_BUCKETS | Список разрешенных имен контейнеров S3, разделенных запятыми | (пустой) |
S3_MAX_BUCKETS | Максимальное количество сегментов для возврата в листинге | 5 |
AWS_ACCESS_KEY_ID | Ключ доступа AWS (если не используются учетные данные по умолчанию) | (из конфигурации AWS) |
AWS_SECRET_ACCESS_KEY | Секретный ключ 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.json
- Windows:
%APPDATA%\Claude\claude_desktop_config.json
- macOS:
- Добавьте сервер S3 MCP в конфигурацию:
Вариант Docker для Claude Desktop 🐳
Вы также можете настроить Claude Desktop для использования работающего контейнера Docker для сервера MCP:
⚠️ Важные предварительные условия : для работы этой конфигурации Docker вам СЛЕДУЕТ сначала собрать и запустить контейнер Docker ПЕРЕД запуском Claude Desktop:
CopyБез запущенного контейнера 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 для выполнения запроса и покажет вам результаты.
Лицензия
Массачусетский технологический институт
You must be authenticated.
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.
Сервер протокола контекста модели Amazon S3, который позволяет крупным языковым моделям, таким как Claude, взаимодействовать с хранилищем AWS S3, предоставляя инструменты для перечисления контейнеров, перечисления объектов и извлечения содержимого объектов.
Related MCP Servers
- -securityAlicense-qualityA Model Context Protocol server that enables Claude to execute Python code using boto3 to query and manage AWS resources directly from conversations.Last updated -6PythonMIT License
- AsecurityFlicenseAqualityAn MCP server that provides tools for interacting with AWS S3 buckets, enabling direct access to S3 operations through the Model Context Protocol.Last updated -1Python
- AsecurityAlicenseAqualityA Model Context Protocol server implementation that enables Claude to perform AWS operations on S3 and DynamoDB services through natural language commands.Last updated -2392PythonMIT License
- -securityFlicense-qualityA Model Context Protocol server allowing Claude AI to interact with AWS resources through natural language, enabling users to query and manage AWS services without using the traditional AWS Console or CLI.Last updated -TypeScript