Projet MCP Server-Client
An implementation of the Model Context Protocol (MCP) for communication between AI models and external tools, featuring server and client examples in Python and Spring Boot.
Projet MCP Server-Client
Présentation du projet
Ce projet est une implémentation du protocole MCP (Model Context Protocol) qui permet la communication entre des modèles d'IA et des outils externes. L'application est composée de trois composants principaux:
- Serveur MCP Python - Un serveur MCP léger écrit en Python utilisant la bibliothèque FastMCP
- Serveur MCP Spring Boot - Un serveur MCP basé sur Spring Boot utilisant le protocole SSE (Server-Sent Events)
- Client MCP Spring Boot - Un client qui se connecte aux serveurs MCP et utilise l'API Anthropic Claude pour les fonctionnalités d'IA
Structure du projet
mcp-server-client-spring-ai-main/
│
├── python-mcp-server/ # Serveur MCP Python
│ ├── server.py # Point d'entrée du serveur MCP Python
│ └── main.py # Fichier Python principal
│
├── sse-mcp-server/ # Serveur MCP Spring Boot
│ ├── pom.xml # Configuration Maven
│ └── src/ # Code source Java
│
├── mcp-client/ # Client MCP Spring Boot
│ ├── pom.xml # Configuration Maven
│ ├── src/ # Code source Java
│ └── resources/ # Fichiers de configuration
│ ├── application.properties # Configuration principale
│ ├── application-secrets.properties # Clés API (non versionnées)
│ └── mcp-servers.json # Configuration des serveurs MCP
│
└── run-all.bat # Script pour démarrer tous les composants
Prérequis
- Java 21 ou supérieur
- Python 3.10 ou supérieur
- Maven (inclus via les wrappers mvnw)
- Clé API Anthropic Claude
Installation
- Installation des dépendances Python
cd python-mcp-server
pip install fastmcp
- Configuration de la clé API Anthropic (OBLIGATOIRE)
L'application nécessite une clé API Anthropic Claude valide pour fonctionner. Sans cette clé, vous recevrez une erreur d'authentification (HTTP 401 - invalid x-api-key).
Voici comment configurer la clé API:
a) Créez un fichier application-secrets.properties dans le dossier mcp-client/src/main/resources/ basé sur le modèle fourni:
# Clé API Anthropic
spring.ai.anthropic.api-key=sk-ant-api03-VOTRE_CLÉ_API_ICI
b) Alternativement, vous pouvez définir une variable d'environnement système nommée CLAUDE_API_KEY avec votre clé API comme valeur.
IMPORTANT: Ne partagez jamais votre clé API et ne la publiez pas sur GitHub ou tout autre dépôt public. Le fichier
application-secrets.propertiesest automatiquement ignoré par Git pour protéger votre clé.
Démarrage de l'application
Prérequis avant démarrage
- Assurez-vous que vous avez bien configuré votre clé API Anthropic (voir section précédente)
- Vérifiez que Python est installé et que la bibliothèque FastMCP est disponible
- Si vous utilisez le serveur filesystem, vérifiez que Node.js est installé et accessible
Méthode 1: Démarrage automatisé (recommandée)
Utilisez le script batch qui lance tous les composants dans l'ordre correct avec les délais appropriés:
run-all.bat
Ce script:
- Démarre d'abord le serveur MCP Python dans une fenêtre séparée
- Attend 3 secondes pour l'initialisation
- Démarre le serveur MCP Spring Boot dans une deuxième fenêtre
- Attend 5 secondes pour l'initialisation
- Lance le client MCP dans la fenêtre actuelle
Méthode 2: Démarrage manuel des composants
Si vous préférez un contrôle plus précis, vous pouvez démarrer chaque composant manuellement dans cet ordre:
- Démarrer le serveur MCP Python
cd python-mcp-server
python server.py
- Démarrer le serveur MCP Spring Boot
cd sse-mcp-server
./mvnw spring-boot:run # Sous Windows: mvnw.cmd spring-boot:run
- Démarrer le client MCP
cd mcp-client
./mvnw spring-boot:run # Sous Windows: mvnw.cmd spring-boot:run
Accès à l'application
Une fois démarrée, l'application client est accessible à:
- URL:
http://localhost:8080 - Le serveur Python MCP s'exécute sur le port 8878
- Le serveur Spring Boot MCP s'exécute sur le port 8877
Architecture
Le système utilise le protocole MCP (Model Context Protocol) pour permettre la communication entre différents composants:
- Le Serveur MCP Python fournit des outils simples comme la récupération d'informations sur les employés
- Le Serveur MCP Spring Boot fournit des services supplémentaires via Spring Boot
- Le Client MCP se connecte à ces serveurs pour accéder à leurs outils et les expose à travers une interface web
Configuration
Configuration du client MCP
Le fichier application.properties contient la configuration principale:
# Configuration du client MCP
spring.ai.mcp.client.type=sync
spring.ai.mcp.client.connection-timeout=60000
spring.ai.mcp.client.read-timeout=60000
spring.ai.mcp.client.sse.connections.server1.url=http://localhost:8877
Configuration des serveurs MCP
Le fichier mcp-servers.json définit les serveurs MCP disponibles:
{
"mcpServers": {
"filesystem": {
"command": "C:/Program Files/nodejs/npx.cmd",
"args": [
"-y",
"@modelcontextprotocol/server-filesystem",
"chemin/vers/dossier"
]
},
"Python-MCP-Server": {
"command": "python",
"args": [
"chemin/vers/server.py"
]
}
}
}
Sécurité
Les clés API sensibles sont stockées dans un fichier application-secrets.properties qui est exclu du contrôle de version Git. Ne partagez jamais ce fichier et ne l'incluez pas dans vos commits.
Dépannage
-
Erreur "Invalid x-api-key"
- Vérifiez que votre clé API Anthropic est correctement configurée dans
application-secrets.properties
- Vérifiez que votre clé API Anthropic est correctement configurée dans
-
Erreur "Cannot run program 'npx'"
- Vérifiez que Node.js est installé ou désactivez le serveur filesystem en ajoutant:
spring.ai.mcp.client.stdio.filesystem.auto-initialization.enabled=falsedansapplication.properties
-
Problèmes de connexion au serveur MCP
- Vérifiez que les serveurs MCP sont en cours d'exécution
- Vérifiez les paramètres de timeout dans
application.properties
Contribution
Pour contribuer à ce projet, veuillez:
- Forker le dépôt
- Créer une branche pour votre fonctionnalité (
git checkout -b nouvelle-fonctionnalite) - Valider vos modifications (
git commit -am 'Ajouter une nouvelle fonctionnalité') - Pousser vers la branche (
git push origin nouvelle-fonctionnalite) - Créer une Pull Request
Licence
Ce projet est distribué sous licence MIT.
Related Servers
Scout Monitoring MCP
sponsorPut performance and error data directly in the hands of your AI assistant.
Alpha Vantage MCP Server
sponsorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
Enrichr MCP Server
Performs gene set enrichment analysis using the Enrichr API, supporting all available gene set libraries.
BlenderMCP
Connects Blender to Claude AI via the Model Context Protocol (MCP), enabling direct AI interaction for prompt-assisted 3D modeling, scene creation, and manipulation.
Next.js MCP Server
A Next.js-based MCP server with OAuth 2.1 authentication support using Google as the default provider. Requires a PostgreSQL database and optionally Redis for SSE transport.
SSH Server MCP
An MCP server that provides SSH-based remote management tools, acting as proxy
mcproc
Manage background processes for AI agents using the Model Context Protocol (MCP).
GitHub Actions
An MCP Server for the GitHub Actions API, enabling AI assistants to manage and operate GitHub Actions workflows.
Stack AI
Build and deploy AI applications using the Stack AI platform.
Flowise
Integrate with the Flowise API to create predictions and manage chatflows and assistants.
UML-MCP
A diagram generation server supporting multiple UML and other diagram types, with various output formats. It integrates with rendering services like Kroki and PlantUML.
Monad MCP Server
Interact with the Monad testnet, query blockchain data, and engage with the CoinflipGame smart contract.