Na konci tohoto labu budete schopni:
- ✅ Vytvořit vlastní MCP servery pomocí AI Toolkit
- ✅ Nakonfigurovat a používat nejnovější MCP Python SDK (verze 1.9.3)
- ✅ Nastavit a využívat MCP Inspector pro ladění
- ✅ Ladit MCP servery v prostředí Agent Builder i Inspector
- ✅ Porozumět pokročilým pracovním postupům vývoje MCP serverů
- Dokončení Labu 2 (Základy MCP)
- VS Code s nainstalovaným rozšířením AI Toolkit
- Prostředí Python 3.10+
- Node.js a npm pro nastavení Inspectoru
V tomto labu vytvoříte Weather MCP Server, který demonstruje:
- Vlastní implementaci MCP serveru
- Integraci s AI Toolkit Agent Builderem
- Profesionální pracovní postupy ladění
- Moderní způsoby využití MCP SDK
Model Context Protocol Python SDK poskytuje základ pro tvorbu vlastních MCP serverů. Budete používat verzi 1.9.3 s rozšířenými možnostmi ladění.
Výkonný nástroj pro ladění, který nabízí:
- Monitorování serveru v reálném čase
- Vizualizaci spouštění nástrojů
- Kontrolu síťových požadavků a odpovědí
- Interaktivní testovací prostředí
- Spusťte Agent Builder ve VS Code přes rozšíření AI Toolkit
- Vytvořte nového agenta s následující konfigurací:
- Název agenta:
WeatherAgent
- Název agenta:
- Přejděte do Tools → Add Tool v Agent Builderu
- Vyberte "MCP Server" z dostupných možností
- Zvolte "Create A new MCP Server"
- Vyberte šablonu
python-weather - Pojmenujte server:
weather_mcp
- Otevřete vygenerovaný projekt ve VS Code
- Prohlédněte si strukturu projektu:
weather_mcp/ ├── src/ │ ├── __init__.py │ └── server.py ├── inspector/ │ ├── package.json │ └── package-lock.json ├── .vscode/ │ ├── launch.json │ └── tasks.json ├── pyproject.toml └── README.md
🔍 Proč aktualizovat? Chceme využít nejnovější MCP SDK (verze 1.9.3) a službu Inspector (0.14.0) pro lepší funkce a ladění.
Upravte pyproject.toml: aktualizace v ./code/weather_mcp/pyproject.toml
Upravte inspector/package.json: aktualizace v ./code/weather_mcp/inspector/package.json
Upravte inspector/package-lock.json: aktualizace v ./code/weather_mcp/inspector/package-lock.json
📝 Poznámka: Tento soubor obsahuje rozsáhlé definice závislostí. Níže je základní struktura – kompletní obsah zajišťuje správné vyřešení závislostí.
⚡ Kompletní package-lock: Plný package-lock.json obsahuje cca 3000 řádků definic závislostí. Výše je klíčová struktura – pro kompletní vyřešení použijte poskytnutý soubor.
Poznámka: Prosím zkopírujte soubor na uvedenou cestu a nahraďte odpovídající lokální soubor
Upravte .vscode/launch.json:
{
"version": "0.2.0",
"configurations": [
{
"name": "Attach to Local MCP",
"type": "debugpy",
"request": "attach",
"connect": {
"host": "localhost",
"port": 5678
},
"presentation": {
"hidden": true
},
"internalConsoleOptions": "neverOpen",
"postDebugTask": "Terminate All Tasks"
},
{
"name": "Launch Inspector (Edge)",
"type": "msedge",
"request": "launch",
"url": "http://localhost:6274?timeout=60000&serverUrl=http://localhost:3001/sse#tools",
"cascadeTerminateToConfigurations": [
"Attach to Local MCP"
],
"presentation": {
"hidden": true
},
"internalConsoleOptions": "neverOpen"
},
{
"name": "Launch Inspector (Chrome)",
"type": "chrome",
"request": "launch",
"url": "http://localhost:6274?timeout=60000&serverUrl=http://localhost:3001/sse#tools",
"cascadeTerminateToConfigurations": [
"Attach to Local MCP"
],
"presentation": {
"hidden": true
},
"internalConsoleOptions": "neverOpen"
}
],
"compounds": [
{
"name": "Debug in Agent Builder",
"configurations": [
"Attach to Local MCP"
],
"preLaunchTask": "Open Agent Builder",
},
{
"name": "Debug in Inspector (Edge)",
"configurations": [
"Launch Inspector (Edge)",
"Attach to Local MCP"
],
"preLaunchTask": "Start MCP Inspector",
"stopAll": true
},
{
"name": "Debug in Inspector (Chrome)",
"configurations": [
"Launch Inspector (Chrome)",
"Attach to Local MCP"
],
"preLaunchTask": "Start MCP Inspector",
"stopAll": true
}
]
}Upravte .vscode/tasks.json:
{
"version": "2.0.0",
"tasks": [
{
"label": "Start MCP Server",
"type": "shell",
"command": "python -m debugpy --listen 127.0.0.1:5678 src/__init__.py sse",
"isBackground": true,
"options": {
"cwd": "${workspaceFolder}",
"env": {
"PORT": "3001"
}
},
"problemMatcher": {
"pattern": [
{
"regexp": "^.*$",
"file": 0,
"location": 1,
"message": 2
}
],
"background": {
"activeOnStart": true,
"beginsPattern": ".*",
"endsPattern": "Application startup complete|running"
}
}
},
{
"label": "Start MCP Inspector",
"type": "shell",
"command": "npm run dev:inspector",
"isBackground": true,
"options": {
"cwd": "${workspaceFolder}/inspector",
"env": {
"CLIENT_PORT": "6274",
"SERVER_PORT": "6277",
}
},
"problemMatcher": {
"pattern": [
{
"regexp": "^.*$",
"file": 0,
"location": 1,
"message": 2
}
],
"background": {
"activeOnStart": true,
"beginsPattern": "Starting MCP inspector",
"endsPattern": "Proxy server listening on port"
}
},
"dependsOn": [
"Start MCP Server"
]
},
{
"label": "Open Agent Builder",
"type": "shell",
"command": "echo ${input:openAgentBuilder}",
"presentation": {
"reveal": "never"
},
"dependsOn": [
"Start MCP Server"
],
},
{
"label": "Terminate All Tasks",
"command": "echo ${input:terminate}",
"type": "shell",
"problemMatcher": []
}
],
"inputs": [
{
"id": "openAgentBuilder",
"type": "command",
"command": "ai-mlstudio.agentBuilder",
"args": {
"initialMCPs": [ "local-server-weather_mcp" ],
"triggeredFrom": "vsc-tasks"
}
},
{
"id": "terminate",
"type": "command",
"command": "workbench.action.tasks.terminate",
"args": "terminateAll"
}
]
}
Po provedení změn konfigurace spusťte následující příkazy:
Instalace Python závislostí:
uv syncInstalace závislostí Inspectoru:
cd inspector
npm install- Stiskněte F5 nebo použijte konfiguraci "Debug in Agent Builder"
- Vyberte složenou konfiguraci v panelu ladění
- Počkejte na spuštění serveru a otevření Agent Builderu
- Otestujte svůj weather MCP server pomocí dotazů v přirozeném jazyce
Zadejte prompt jako tento
SYSTEM_PROMPT
You are my weather assistant
USER_PROMPT
How's the weather like in Seattle
- Použijte konfiguraci "Debug in Inspector" (v Edge nebo Chrome)
- Otevřete rozhraní Inspectoru na adrese
http://localhost:6274 - Prozkoumejte interaktivní testovací prostředí:
- Zobrazte dostupné nástroje
- Otestujte spouštění nástrojů
- Sledujte síťové požadavky
- Laděte odpovědi serveru
Dokončením tohoto labu jste:
- Vytvořili vlastní MCP server pomocí šablon AI Toolkit
- Aktualizovali na nejnovější MCP SDK (verze 1.9.3) pro rozšířené funkce
- Nakonfigurovali profesionální pracovní postupy ladění pro Agent Builder i Inspector
- Nastavili MCP Inspector pro interaktivní testování serveru
- Ovládáte konfigurace ladění ve VS Code pro vývoj MCP
| Funkce | Popis | Použití |
|---|---|---|
| MCP Python SDK v1.9.3 | Nejnovější implementace protokolu | Moderní vývoj serverů |
| MCP Inspector 0.14.0 | Interaktivní nástroj pro ladění | Testování serveru v reálném čase |
| Ladění ve VS Code | Integrované vývojové prostředí | Profesionální pracovní postup ladění |
| Integrace Agent Builderu | Přímé propojení s AI Toolkit | Kompletní testování agenta |
- Dokumentace MCP Python SDK
- Průvodce rozšířením AI Toolkit
- Dokumentace ladění ve VS Code
- Specifikace Model Context Protocol
🎉 Gratulujeme! Úspěšně jste dokončili Lab 3 a nyní umíte vytvářet, ladit a nasazovat vlastní MCP servery s profesionálními pracovními postupy.
Jste připraveni aplikovat své MCP dovednosti v reálném vývojovém workflow? Pokračujte do Modulu 4: Praktický vývoj MCP - Vlastní GitHub Clone Server, kde:
- Vytvoříte produkčně připravený MCP server automatizující operace s GitHub repozitáři
- Implementujete funkci klonování GitHub repozitářů přes MCP
- Integrujete vlastní MCP servery s VS Code a GitHub Copilot Agent Mode
- Testujete a nasadíte vlastní MCP servery v produkčním prostředí
- Naučíte se praktickou automatizaci pracovních postupů pro vývojáře
Prohlášení o vyloučení odpovědnosti:
Tento dokument byl přeložen pomocí AI překladatelské služby Co-op Translator. I když usilujeme o přesnost, mějte prosím na paměti, že automatické překlady mohou obsahovat chyby nebo nepřesnosti. Původní dokument v jeho mateřském jazyce by měl být považován za závazný zdroj. Pro důležité informace se doporučuje profesionální lidský překlad. Nejsme odpovědní za jakékoliv nedorozumění nebo nesprávné výklady vyplývající z použití tohoto překladu.



