FastMCP ist ein TypeScript-Framework, das speziell für die Entwicklung von Model Context Protocol (MCP) Servern entwickelt wurde. Es bietet ein umfassendes Set an Tools und Funktionen, das es Entwicklern ermöglicht, schnell leistungsstarke MCP-Server zu erstellen, die Client-Sitzungen verarbeiten können.
Projektadresse: https://github.com/punkpeye/fastmcp
npm install fastmcp
import { FastMCP } from "fastmcp";
import { z } from "zod";
const server = new FastMCP({
name: "My Server",
version: "1.0.0",
});
server.addTool({
name: "add",
description: "Add two numbers",
parameters: z.object({
a: z.number(),
b: z.number(),
}),
execute: async (args) => {
return String(args.a + args.b);
},
});
server.start({
transportType: "stdio",
});
Tools ermöglichen es dem Server, ausführbare Funktionen für Clients freizugeben, die von Clients aufgerufen und von LLMs zur Ausführung von Operationen verwendet werden können.
import { z } from "zod";
server.addTool({
name: "fetch-zod",
description: "Fetch the content of a url (using Zod)",
parameters: z.object({
url: z.string(),
}),
execute: async (args) => {
return await fetchWebpageContent(args.url);
},
});
Tools können Annotationen enthalten, die reichhaltigere Kontext- und Kontrollinformationen liefern:
server.addTool({
name: "fetch-content",
description: "Fetch content from a URL",
parameters: z.object({
url: z.string(),
}),
annotations: {
title: "Web Content Fetcher",
readOnlyHint: true,
openWorldHint: true,
},
execute: async (args) => {
return await fetchWebpageContent(args.url);
},
});
Ressourcen repräsentieren jede Art von Daten, die der MCP-Server dem Client zur Verfügung stellen möchte, einschließlich:
server.addResource({
uri: "file:///logs/app.log",
name: "Application Logs",
mimeType: "text/plain",
async load() {
return {
text: await readLogFile(),
};
},
});
server.addResourceTemplate({
uriTemplate: "file:///logs/{name}.log",
name: "Application Logs",
mimeType: "text/plain",
arguments: [
{
name: "name",
description: "Name of the log",
required: true,
},
],
async load({ name }) {
return {
text: `Example log content for ${name}`,
};
},
});
Prompts ermöglichen es dem Server, wiederverwendbare Prompt-Templates und Workflows zu definieren:
server.addPrompt({
name: "git-commit",
description: "Generate a Git commit message",
arguments: [
{
name: "changes",
description: "Git diff or description of changes",
required: true,
},
],
load: async (args) => {
return `Generate a concise but descriptive commit message for these changes:\n\n${args.changes}`;
},
});
FastMCP unterstützt benutzerdefinierte Authentifizierungsfunktionen:
import { AuthError } from "fastmcp";
const server = new FastMCP({
name: "My Server",
version: "1.0.0",
authenticate: ({ request }) => {
const apiKey = request.headers["x-api-key"];
if (apiKey !== "123") {
throw new Response(null, {
status: 401,
statusText: "Unauthorized",
});
}
return {
id: 1,
};
},
});
Unterstützung für die SSE-Funktion zur Echtzeitkommunikation:
server.start({
transportType: "sse",
sse: {
endpoint: "/sse",
port: 8080,
},
});
FastMCP weist jeder Client-Verbindung eine neue Serverinstanz zu, um eine 1:1-Kommunikation zu ermöglichen:
server.on("connect", (event) => {
console.log("Client connected:", event.session);
});
server.on("disconnect", (event) => {
console.log("Client disconnected:", event.session);
});
npx fastmcp dev src/examples/addition.ts
npx fastmcp inspect src/examples/addition.ts
Fügen Sie die Konfiguration in Claude Desktop hinzu:
{
"mcpServers": {
"my-mcp-server": {
"command": "npx",
"args": ["tsx", "/PATH/TO/YOUR_PROJECT/src/index.ts"],
"env": {
"YOUR_ENV_VAR": "value"
}
}
}
}
FastMCP wurde in mehreren Projekten eingesetzt, darunter:
FastMCP ist ein leistungsstarkes und einfach zu bedienendes TypeScript-Framework, das eine vollständige Lösung für die Entwicklung von MCP-Servern bietet. Ob einfache Tool-Integration oder komplexer KI-Serviceaufbau, FastMCP bietet die erforderlichen Funktionen und Flexibilität. Sein reichhaltiger Funktionsumfang und die gute Entwicklererfahrung machen es zu einem wichtigen Werkzeug im MCP-Ökosystem.