Dette repository indeholder en Python-implementering af Model Context Protocol (MCP), som viser, hvordan man opretter både en server- og en klientapplikation, der kommunikerer ved hjælp af MCP-standarden.
MCP-implementeringen består af to hovedkomponenter:
-
MCP Server (
server.py) - En server, der eksponerer:- Værktøjer: Funktioner, der kan kaldes eksternt
- Ressourcer: Data, der kan hentes
- Prompter: Skabeloner til at generere prompts til sprogmodeller
-
MCP Klient (
client.py) - En klientapplikation, der forbinder til serveren og bruger dens funktioner
Denne implementering demonstrerer flere centrale MCP-funktioner:
completion- Genererer tekstfuldførelser fra AI-modeller (simuleret)add- Enkel lommeregner, der lægger to tal sammen
models://- Returnerer information om tilgængelige AI-modellergreeting://{name}- Returnerer en personlig hilsen til et givent navn
review_code- Genererer en prompt til kodegennemgang
For at bruge denne MCP-implementering, installer de nødvendige pakker:
pip install mcp-server mcp-clientKør serveren i et terminalvindue:
python server.pyServeren kan også køres i udviklingstilstand ved hjælp af MCP CLI:
mcp dev server.pyEller installeres i Claude Desktop (hvis tilgængelig):
mcp install server.pyKør klienten i et andet terminalvindue:
python client.pyDette vil forbinde til serveren og demonstrere alle tilgængelige funktioner.
Klienten (client.py) demonstrerer alle MCP-funktionaliteter:
python client.pyDette vil forbinde til serveren og afprøve alle funktioner, inklusive værktøjer, ressourcer og prompter. Outputtet vil vise:
- Resultat fra lommeregner-værktøjet (5 + 7 = 12)
- Svar fra completion-værktøjet på "What is the meaning of life?"
- Liste over tilgængelige AI-modeller
- Personlig hilsen til "MCP Explorer"
- Skabelon til kodegennemgangsprompt
Serveren er implementeret ved hjælp af FastMCP API’en, som tilbyder højniveau-abstraktioner til at definere MCP-tjenester. Her er et forenklet eksempel på, hvordan værktøjer defineres:
@mcp.tool()
def add(a: int, b: int) -> int:
"""Add two numbers together
Args:
a: First number
b: Second number
Returns:
The sum of the two numbers
"""
logger.info(f"Adding {a} and {b}")
return a + bKlienten bruger MCP-klientbiblioteket til at forbinde til og kalde serveren:
async with stdio_client(server_params) as (reader, writer):
async with ClientSession(reader, writer) as session:
await session.initialize()
result = await session.call_tool("add", arguments={"a": 5, "b": 7})For mere information om MCP, besøg: https://modelcontextprotocol.io/
Ansvarsfraskrivelse:
Dette dokument er blevet oversat ved hjælp af AI-oversættelsestjenesten Co-op Translator. Selvom vi bestræber os på nøjagtighed, bedes du være opmærksom på, at automatiserede oversættelser kan indeholde fejl eller unøjagtigheder. Det oprindelige dokument på dets oprindelige sprog bør betragtes som den autoritative kilde. For kritisk information anbefales professionel menneskelig oversættelse. Vi påtager os intet ansvar for misforståelser eller fejltolkninger, der opstår som følge af brugen af denne oversættelse.