hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
AWS Cost Explorer 및 Amazon Bedrock 모델 호출 로그 MCP 서버 및 클라이언트
Anthropic의 MCP(모델 제어 프로토콜)를 통해 Cost Explorer를 통해 AWS 지출 데이터를 가져오고, Amazon Cloud Watch의 Model invocation logs
통해 Amazon Bedrock 사용 데이터를 가져오는 MCP 서버입니다. HTTPS를 통해 MCP 서버를 실행하는 방법은 "보안" 원격 MCP 서버 섹션을 참조하십시오.
지엑스피1
MCP 서버를 로컬에서 실행하고 Claude Desktop을 통해 액세스할 수 있습니다. 또는 Amazon EC2에서 원격 MCP 서버를 실행하고 LangGraph Agent에 내장된 MCP 클라이언트를 통해 액세스할 수도 있습니다.
🚨MCP 서버에서 사용하는 IAM 역할이 다른 계정에서 역할을 수행할 수 있는 한, 이 MCP 서버를 사용하여 다른 계정에서 AWS 지출 정보를 가져올 수도 있습니다.🚨
데모 비디오
개요
이 도구는 Anthropic의 Claude 모델을 대화형 인터페이스로 사용하여 AWS 클라우드 지출 데이터를 편리하게 분석하고 시각화할 수 있는 방법을 제공합니다. AWS Cost Explorer API 기능을 Claude Desktop에 제공하는 MCP 서버 역할을 하며, 이를 통해 AWS 지출에 대한 질문을 자연어로 작성할 수 있습니다.
특징
- Amazon EC2 지출 분석 : 지난 하루 동안의 EC2 지출에 대한 자세한 분석을 확인하세요.
- Amazon Bedrock 지출 분석 : 지난 30일 동안 지역, 사용자 및 모델별 세부 내역 보기
- 서비스 지출 보고서 : 지난 30일 동안 모든 AWS 서비스의 지출을 분석합니다.
- 자세한 비용 분석 : 일, 지역, 서비스 및 인스턴스 유형별로 세부적인 비용 데이터를 가져옵니다.
- 대화형 인터페이스 : Claude를 사용하여 자연어로 비용 데이터를 쿼리합니다.
요구 사항
- 파이썬 3.12
- Cost Explorer 액세스 권한이 있는 AWS 자격 증명
- Anthropic API 액세스(Claude 통합용)
- [선택 사항] Amazon Bedrock 액세스(LangGraph Agent용)
- [선택 사항] 원격 MCP 서버를 실행하기 위한 Amazon EC2
설치
uv
설치 :Copy추가 설치 옵션은 여기에 문서화되어 있습니다.Copy- 이 저장소를 복제합니다. (aws-samples를 가리키도록 업데이트된다고 가정하고요?)Copy
- Python 가상 환경을 설정하고 종속성을 설치합니다.Copy
- AWS 자격 증명을 구성하세요.AWS IAM Identity Center를 사용하는 경우 문서 에 따라 단기 자격 증명을 구성하세요.Copy
용법
필수 조건
- Amazon CloudWatch에서 모델 호출 로그를 설정합니다.
- 사용 중인 IAM 사용자/역할에 Amazon Cost Explorer 및 Amazon CloudWatch에 대한 전체 읽기 전용 권한이 있는지 확인하세요. 이는 MCP 서버가 해당 서비스에서 데이터를 검색하는 데 필수적입니다. 요구 사항에 따라 사용 및 수정할 수 있는 정책 샘플은 여기 와 여기를 참조하세요.
- MCP 서버가 다른 계정의 AWS 지출 정보에 액세스할 수 있도록 하려면 서버를 시작하는 동안
CROSS_ACCOUNT_ROLE_NAME
매개변수를 설정합니다. 그러면 에이전트와 상호 작용하는 동안 다른 계정에 대한 AWS 계정 ID를 제공할 수 있으며, 에이전트는 해당 계정 ID를 서버에 전달합니다.
로컬 설정
MCP의 전송 수단으로 stdio
사용합니다. MCP 서버와 클라이언트는 모두 로컬 머신에서 실행됩니다.
서버 시작(로컬)
다음을 사용하여 서버를 실행합니다.
클로드 데스크톱 구성
Claude Desktop으로 이 도구를 구성하는 방법은 두 가지가 있습니다.
옵션 1: Docker 사용
Claude Desktop 설정 파일에 다음을 추가하세요. 운영 체제에 따라 다음 경로에서 파일을 찾을 수 있습니다.
- macOS: ~/라이브러리/애플리케이션 지원/클로드/클로드_데스크탑_config.json.
- 윈도우: %APPDATA%\Claude\claude_desktop_config.json.
- 리눅스: ~/.config/Claude/claude_desktop_config.json.
중요 :
YOUR_ACCESS_KEY_ID
와YOUR_SECRET_ACCESS_KEY
실제 AWS 자격 증명으로 바꾸세요. 실제 자격 증명을 버전 관리 시스템에 커밋하지 마세요.
옵션 2: UV 사용(Docker 없이)
Docker 없이 서버를 직접 실행하려면 UV를 사용할 수 있습니다.
디렉토리 경로를 시스템의 저장소에 대한 실제 경로로 바꿔야 합니다.
원격 설정
MCP의 전송 수단으로 sse
사용하며, EC2의 MCP 서버와 클라이언트는 로컬 머신에서 실행됩니다. Claude Desktop은 현재 원격 MCP 서버를 지원하지 않습니다(GitHub 이슈 참조 ).
서버 시작(원격)
위와 동일한 지침에 따라 Amazon EC2에서 원격 MCP 서버를 시작할 수 있습니다. 아래와 같이 MCP_TRANSPORT
sse
(서버 측 이벤트)로 설정해야 합니다. MCP는 JSON-RPC 2.0을 와이어 형식으로 사용하므로 프로토콜 자체에는 권한 부여 및 인증 기능이 포함되어 있지 않습니다( GitHub 이슈 참조). MCP를 통해 민감한 데이터를 주고받지 마십시오 .
다음을 사용하여 서버를 실행합니다.
- MCP 서버는 TCP 포트 8000에서 수신을 시작합니다.
- 로컬 머신(MCP 클라이언트/LangGraph 기반 앱을 실행 중인 곳)에서 EC2 인스턴스로의 TCP 포트 8000에 대한 액세스를 허용하도록 EC2 인스턴스와 연결된 보안 그룹에서 수신 규칙을 구성합니다.
또한 "보안" 원격 MCP 서버 (즉, MCP 클라이언트가 HTTPS를 통해 연결할 수 있는 서버)를 실행하는 방법에 대한 섹션도 참조하세요.
CLI MCP 클라이언트로 테스트
mcp_sse_client.py
스크립트를 사용하여 원격 MCP 서버를 테스트할 수 있습니다. 이 스크립트를 실행하면 MCP 서버에서 사용 가능한 도구 목록과 get_bedrock_daily_usage_stats
도구의 출력이 출력됩니다.
Chainlit 앱으로 테스트
이 저장소의 app.py
파일은 LangChain MCP Adapter
사용하여 MCP 서버에서 제공하는 도구를 LangGraph 에이전트의 도구로 가져오는 LangGraph 에이전트를 생성하는 Chainlit 앱(챗봇)을 제공합니다. 에이전트는 LLM을 사용하여 사용자 질문에 답변하고 필요에 따라 사용 가능한 도구를 사용할 수 있습니다. 사용자가 " 지난 일주일 동안 내 Bedrock 사용량은 어땠나요? "와 같은 질문을 하면 에이전트는 원격 MCP 서버를 통해 사용 가능한 도구를 사용하여 해당 질문에 답변합니다. 이 에이전트는 Amazon Bedrock에서 제공하는 Claude 3.5 Haiku 모델을 사용합니다.
다음을 사용하여 Chainlit 앱을 실행합니다.
localhost:8080
에서 브라우저 창이 열리고 챗봇을 사용하여 AWS 지출에 대한 세부 정보를 얻을 수 있습니다.
사용 가능한 도구
서버는 Claude가 사용할 수 있는 다음 도구를 제공합니다.
get_ec2_spend_last_day()
: 전날의 EC2 지출 데이터를 검색합니다.get_detailed_breakdown_by_day(days=7)
: 지역, 서비스 및 인스턴스 유형별 비용에 대한 포괄적인 분석을 제공합니다.get_bedrock_daily_usage_stats(days=7, region='us-east-1', log_group_name='BedrockModelInvocationLogGroup')
: 지역 및 사용자별 모델 사용에 대한 일별 세부 정보를 제공합니다.get_bedrock_hourly_usage_stats(days=7, region='us-east-1', log_group_name='BedrockModelInvocationLogGroup')
: 지역 및 사용자별 모델 사용에 대한 일별, 시간별 세부 정보를 제공합니다.
예제 쿼리
MCP 지원 인터페이스를 통해 Claude에 연결하면 다음과 같은 질문을 할 수 있습니다.
- "지난 몇 주 동안의 Bedrock 지출을 이해하도록 도와주세요"
- "어제 내 EC2 지출은 얼마였나요?"
- "지난 달 비용별 상위 5개 AWS 서비스를 보여주세요"
- "지난 14일 동안 지역별 지출을 분석해 보세요"
- "어떤 인스턴스 유형이 가장 비용이 많이 드나요?"
- "어떤 서비스의 비용이 전월 대비 가장 크게 증가했습니까?"
도커 지원
컨테이너화된 배포를 위해 Dockerfile이 포함되어 있습니다.
개발
프로젝트 구조
server.py
: MCP 도구를 사용한 메인 서버 구현pyproject.toml
: 프로젝트 종속성 및 메타데이터Dockerfile
: 배포를 위한 컨테이너 정의
새로운 비용 분석 도구 추가
기능을 확장하려면:
server.py
에 새로운 기능 추가@mcp.tool()
로 주석을 달아주세요.- AWS Cost Explorer API 호출 구현
- 읽기 쉬운 형식으로 결과를 포맷하세요
보안 "원격" MCP 서버
nginx
역방향 프록시로 사용하여 MCP 서버 연결에 HTTPS 엔드포인트를 제공할 수 있습니다. 원격 MCP 클라이언트는 HTTPS를 통해 nginx
에 연결할 수 있으며, nginx는 내부적으로 http://localhost:8000
으로 트래픽을 프록시할 수 있습니다. 다음 단계에서는 이 작업을 수행하는 방법을 설명합니다.
- EC2 인스턴스와 연결된 보안 그룹의 인바운드 규칙에서 MCP 클라이언트(노트북이나 다른 곳)의 IP 주소에서 TCP 포트 443에 대한 액세스를 활성화합니다.
- 계속하려면 HTTPS 인증서와 개인 키가 필요합니다. 예를 들어
your-mcp-server-domain-name.com
MCP 서버의 도메인으로 사용하는 경우your-mcp-server-domain-name.com
에 대한 SSL 인증서가 필요하며, MCP 클라이언트는https://your-mcp-server-domain-name.com/sse
로 해당 도메인에 액세스할 수 있습니다. 자체 서명된 인증서를 사용할 수도 있지만, MCP 클라이언트에서 SSL 검증을 비활성화해야 하므로 권장하지 않습니다 . EC2에서 MCP 서버를 호스팅하는 경우 no-ip , Let'Encrypt 또는 이와 유사한 서비스를 사용하여 SSL 인증서를 생성할 수 있습니다. SSL 인증서 파일과 개인 키 파일을 EC2 머신의/etc/ssl/certs
및/etc/ssl/privatekey
폴더에 각각 저장하세요. - 다음 명령을 사용하여 EC2 머신에
nginx
설치합니다.Copy - EC2 인스턴스의 호스트 이름을 가져옵니다. 이는
nginx
역방향 프록시를 구성하는 데 필요합니다.Copy - 다음 내용을 새 파일
/etc/nginx/conf.d/ec2.conf
에 복사합니다.YOUR_EC2_HOSTNAME
,/etc/ssl/certs/cert.pem
,/etc/ssl/privatekey/privkey.pem
설정에 맞는 값으로 바꾸세요.Copy nginx
다시 시작합니다.Copy- 원격 설정 섹션에 설명된 대로 평소처럼 MCP 서버를 시작합니다.
- 이제
https://your-mcp-server-domain-name.com/sse
를 통해 MCP 클라이언트에서 HTTPS를 통해 MCP 서버에 접근할 수 있습니다. - 이제 클라이언트 측(노트북이나 에이전트)에서 다음과 같이 MCP 클라이언트가 MCP 서버와 통신하도록 구성합니다.마찬가지로 HTTPS를 통해 원격 MCP 서버와 통신하기 위해 Chainlit 앱을 실행할 수 있습니다.Copy마찬가지로 LangGraph 에이전트를 실행하여 HTTPS를 통해 원격 MCP 서버와 통신할 수 있습니다.CopyCopy
특허
감사의 말
This server cannot be installed
사용자가 자연어 대화를 통해 AWS Cost Explorer를 쿼리하여 AWS 클라우드 지출 데이터를 분석하고 시각화할 수 있는 명령줄 인터페이스 및 API입니다.
- Demo video
- Overview
- Features
- Requirements
- Installation
- Usage
- Docker Support
- Development
- Secure "remote" MCP server
- License
- Acknowledgments