mcpforge
mcpforge
5줄의 파이썬 코드로 MCP 서버를 배포하세요.
Before After
────── ─────
~200 lines of @serve
JSON-RPC stdio class MarketTools:
boilerplate, schema @tool
generation, error def latest_price(self, symbol: str) -> float: ...
handling, lifecycle @tool
management. def search(self, query: str) -> list[dict]: ...
$ python -m mcpforge run market:MarketTools
✓ MCP server running on stdiomcpforge를 사용하는 이유
MCP(Model Context Protocol)는 Claude, Cursor 및 급성장하는 AI 도구 생태계에서 외부 함수를 호출하기 위해 사용하는 오픈 표준입니다. 강력하지만, 서버를 작성하는 과정은 현재 매우 번거롭습니다.
모든 프로젝트에서 동일한 JSON-RPC 프레이밍, 스키마 생성, 디스패치 루프, 오류 처리를 반복해서 작성해야 합니다. mcpforge는 이 모든 것을 제거합니다. 클래스에 어노테이션을 달고, 메서드에 타입 힌트를 추가하기만 하면 끝입니다.
from mcpforge import serve, tool
@serve(name="market_tools", version="0.1.0")
class MarketTools:
"""Market data tools for AI agents."""
@tool(description="Get the latest price for a symbol")
def latest_price(self, symbol: str) -> float:
return fetch_price(symbol)
@tool
def search(self, query: str, limit: int = 10) -> list[dict]:
"""Search ticker symbols matching `query`."""
return run_search(query, limit)이것으로 사양을 완벽하게 준수하는 MCP 서버가 완성됩니다. 타입 힌트는 JSON 스키마가 되고, 독스트링은 도구 설명이 되며, 반환값은 자동으로 직렬화됩니다.
60초 퀵스타트
pip install mcpforge# hello.py
from mcpforge import serve, tool
@serve(name="hello", version="0.1.0")
class HelloTools:
@tool
def greet(self, name: str = "world") -> str:
"""Say hello to someone."""
return f"Hello, {name}!"python -m mcpforge run hello:HelloTools이제 stdio를 통해 JSON-RPC 2.0으로 통신하는 작동 가능한 MCP 서버가 준비되었습니다.
작동 원리
@serve는 클래스를 MCP 서버(이름, 버전, 기능)로 태그합니다.@tool은 메서드를 MCP 도구로 등록합니다.@resource(uri=...)는 메서드를 MCP 리소스로 등록합니다.mcpforge는 각 메서드의 시그니처를 분석하여 JSON 스키마를 생성합니다. 기본 타입,
list[T],dict[str, T],Literal[...],Optional[T], 데이터 클래스 및 Pydantic 모델 모두 그대로 작동합니다.python -m mcpforge run mod:Class는 stdio 루프를 부팅하고,initialize/tools/list/tools/call/resources/list/resources/read를 처리하며, 적절한 코드로 JSON-RPC 오류를 보고합니다.
외부 MCP SDK가 필요 없습니다. 스키마 편의를 위해 표준 라이브러리 json과 pydantic만 사용합니다.
내장 서버
오늘 바로 사용할 수 있는 두 가지 기본 제공 서버입니다:
# Filesystem tools (sandboxed to a root directory)
python -m mcpforge run mcpforge.builtin.filesystem:FilesystemTools
# HTTP fetch tools
python -m mcpforge run mcpforge.builtin.http:HttpToolsFilesystemTools는 경로 탐색 검사가 포함된 샌드박스 환경에서 list_dir, read_file, search를 제공합니다. HttpTools는 크기 제한이 있는 fetch_url을 제공합니다.
Claude Desktop에 연결
~/Library/Application Support/Claude/claude_desktop_config.json에 추가하세요:
{
"mcpServers": {
"market": {
"command": "python",
"args": ["-m", "mcpforge", "run", "market:MarketTools"],
"cwd": "/path/to/your/project"
}
}
}Claude Desktop을 재시작하면 대화창에 도구가 나타납니다.
Cursor에 연결
~/.cursor/mcp.json:
{
"mcpServers": {
"market": {
"command": "python",
"args": ["-m", "mcpforge", "run", "market:MarketTools"]
}
}
}비교
기능 | mcpforge |
| FastMCP | 직접 구현 |
단일 데코레이터 | 예 | 아니오 | 예 | 아니오 |
타입 기반 자동 JSON 스키마 | 예 | 아니오 | 예 | 아니오 |
Pydantic v2 지원 | 예 | 예 | 예 | 아니오 |
pyd 외 추가 의존성 없음 | 예 | 아니오 | 아니오 | N/A |
내장 fs / http 서버 | 예 | 아니오 | 아니오 | 아니오 |
헬로 월드 코드 라인 수 | ~5 | ~40 | ~10 | ~200 |
와이어 형식 검사
python -m mcpforge inspect market:MarketTools클라이언트가 보게 될 정확한 tools/list 페이로드를 출력합니다.
로드맵
[x] 도구 (호출, 목록)
[x] 리소스 (읽기, 목록)
[x] 타입 힌트 -> JSON 스키마 (Pydantic v2, 데이터 클래스, Literal, Optional)
[x] 내장 파일 시스템 및 http 서버
[ ] 리소스 구독
[ ] 프롬프트 기능
[ ] 샘플링 기능
[ ] WebSocket / HTTP-SSE 전송 (선택적
[http]추가)[ ] 비동기 도구 (
async def)[ ] OTel 추적 훅
라이선스
MIT — LICENSE를 참조하세요.
작성자: thechifura. quantflow 및 strategos의 형제 프로젝트입니다.
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/vigilancetrent/mcpforge'
If you have feedback or need assistance with the MCP directory API, please join our Discord server