Claude Code peut se connecter à des centaines d’outils externes et de sources de données via le Model Context Protocol (MCP), une norme open source pour les intégrations IA-outils. Les serveurs MCP donnent à Claude Code accès à vos outils, bases de données et API. Connectez un serveur lorsque vous vous trouvez à copier des données dans le chat à partir d’un autre outil, comme un suivi de problèmes ou un tableau de bord de surveillance. Une fois connecté, Claude peut lire et agir sur ce système directement au lieu de travailler à partir de ce que vous collez.Documentation Index
Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
Ce que vous pouvez faire avec MCP
Avec les serveurs MCP connectés, vous pouvez demander à Claude Code de :- Implémenter des fonctionnalités à partir de suivi de problèmes : « Ajouter la fonctionnalité décrite dans le problème JIRA ENG-4521 et créer une PR sur GitHub. »
- Analyser les données de surveillance : « Vérifier Sentry et Statsig pour vérifier l’utilisation de la fonctionnalité décrite dans ENG-4521. »
- Interroger les bases de données : « Trouver les e-mails de 10 utilisateurs aléatoires qui ont utilisé la fonctionnalité ENG-4521, en fonction de notre base de données PostgreSQL. »
- Intégrer les conceptions : « Mettre à jour notre modèle d’e-mail standard en fonction des nouvelles conceptions Figma qui ont été publiées sur Slack »
- Automatiser les flux de travail : « Créer des brouillons Gmail invitant ces 10 utilisateurs à une session de rétroaction sur la nouvelle fonctionnalité. »
- Réagir aux événements externes : Un serveur MCP peut également agir comme un canal qui pousse des messages dans votre session, afin que Claude réagisse aux messages Telegram, aux discussions Discord ou aux événements webhook pendant que vous êtes absent.
Trouver et créer des serveurs MCP
Parcourez les connecteurs vérifiés dans le Répertoire Anthropic. Les connecteurs du répertoire utilisent la même infrastructure MCP que Claude Code, vous pouvez donc ajouter n’importe quel serveur distant répertorié avecclaude mcp add.
Pour créer votre propre serveur, consultez le guide du serveur MCP pour les principes fondamentaux du protocole et la documentation de création de connecteurs Claude pour l’authentification, les tests et la soumission au répertoire.
Vous pouvez également faire en sorte que Claude crée un serveur pour vous avec le plugin officiel mcp-server-dev.
Installer le plugin
Dans une session Claude Code, exécutez :Ensuite, exécutez
/reload-plugins pour l’activer dans la session actuelle.Installation des serveurs MCP
Les serveurs MCP peuvent être configurés de trois façons différentes selon vos besoins :Option 1 : Ajouter un serveur HTTP distant
Les serveurs HTTP sont l’option recommandée pour se connecter aux serveurs MCP distants. C’est le transport le plus largement supporté pour les services basés sur le cloud..mcp.json, ~/.claude.json, ou claude mcp add-json, le champ type accepte streamable-http comme alias pour http. La spécification MCP utilise le nom streamable-http pour ce transport, donc les configurations copiées à partir de la documentation du serveur fonctionnent sans modification.
Option 2 : Ajouter un serveur SSE distant
Option 3 : Ajouter un serveur stdio local
Les serveurs Stdio s’exécutent en tant que processus locaux sur votre machine. Ils sont idéaux pour les outils qui ont besoin d’un accès direct au système ou de scripts personnalisés. Claude Code définitCLAUDE_PROJECT_DIR dans l’environnement du serveur généré à la racine du projet, afin que votre serveur puisse résoudre les chemins relatifs au projet sans dépendre du répertoire de travail. C’est le même répertoire que les hooks reçoivent dans leur variable CLAUDE_PROJECT_DIR. Lisez-le depuis l’intérieur de votre processus serveur, par exemple process.env.CLAUDE_PROJECT_DIR en Node ou os.environ["CLAUDE_PROJECT_DIR"] en Python. Votre serveur peut également appeler la demande MCP roots/list, qui retourne le répertoire à partir duquel Claude Code a été lancé.
Cette variable est définie dans l’environnement du serveur, pas dans l’environnement propre de Claude Code, donc la référencer via l’expansion ${VAR} dans un fichier .mcp.json de portée projet ou utilisateur command ou args nécessite une valeur par défaut telle que ${CLAUDE_PROJECT_DIR:-.}. Les configurations MCP fournies par les plugins remplacent ${CLAUDE_PROJECT_DIR} directement et n’ont pas besoin de la valeur par défaut.
Important : Ordre des optionsToutes les options (
--transport, --env, --scope, --header) doivent venir avant le nom du serveur. Le -- (double tiret) sépare ensuite le nom du serveur de la commande et des arguments qui sont passés au serveur MCP.Par exemple :claude mcp add --transport stdio myserver -- npx server→ exécutenpx serverclaude mcp add --transport stdio --env KEY=value myserver -- python server.py --port 8080→ exécutepython server.py --port 8080avecKEY=valuedans l’environnement
Gestion de vos serveurs
Une fois configurés, vous pouvez gérer vos serveurs MCP avec ces commandes :/mcp affiche le nombre d’outils à côté de chaque serveur connecté et signale les serveurs qui annoncent la capacité des outils mais n’exposent aucun outil.
Le nom du serveur workspace est réservé à un usage interne. Si votre configuration définit un serveur avec ce nom, Claude Code le saute au chargement et affiche un avertissement vous demandant de le renommer.
Mises à jour dynamiques des outils
Claude Code supporte les notifications MCPlist_changed, permettant aux serveurs MCP de mettre à jour dynamiquement leurs outils, prompts et ressources disponibles sans vous obliger à vous déconnecter et reconnecter. Lorsqu’un serveur MCP envoie une notification list_changed, Claude Code actualise automatiquement les capacités disponibles de ce serveur.
Reconnexion automatique
Si un serveur HTTP ou SSE se déconnecte en cours de session, Claude Code se reconnecte automatiquement avec un backoff exponentiel : jusqu’à cinq tentatives, en commençant par un délai d’une seconde et en doublant à chaque fois. Le serveur apparaît comme en attente dans/mcp pendant que la reconnexion est en cours. Après cinq tentatives échouées, le serveur est marqué comme échoué et vous pouvez réessayer manuellement à partir de /mcp. Les serveurs Stdio sont des processus locaux et ne sont pas reconnectés automatiquement.
Le même backoff s’applique lorsqu’un serveur HTTP ou SSE échoue sa connexion initiale au démarrage. À partir de la v2.1.121, Claude Code réessaie la connexion initiale jusqu’à trois fois sur les erreurs transitoires telles qu’une réponse 5xx, une connexion refusée ou un délai d’expiration, puis marque le serveur comme échoué s’il ne peut toujours pas se connecter. Les erreurs d’authentification et les erreurs de non-trouvé ne sont pas réessayées car elles nécessitent une modification de la configuration pour être résolues.
Pousser des messages avec des canaux
Un serveur MCP peut également pousser des messages directement dans votre session afin que Claude puisse réagir aux événements externes comme les résultats CI, les alertes de surveillance ou les messages de chat. Pour activer cela, votre serveur déclare la capacitéclaude/channel et vous l’activez avec le drapeau --channels au démarrage. Consultez Canaux pour utiliser un canal officiellement supporté, ou Référence des canaux pour créer le vôtre.
Serveurs MCP fournis par les plugins
Les plugins peuvent regrouper des serveurs MCP, fournissant automatiquement des outils et des intégrations lorsque le plugin est activé. Les serveurs MCP des plugins fonctionnent de manière identique aux serveurs configurés par l’utilisateur. Comment fonctionnent les serveurs MCP des plugins :- Les plugins définissent les serveurs MCP dans
.mcp.jsonà la racine du plugin ou en ligne dansplugin.json - Lorsqu’un plugin est activé, ses serveurs MCP démarrent automatiquement
- Les outils MCP des plugins apparaissent aux côtés des outils MCP configurés manuellement
- Les serveurs des plugins sont gérés via l’installation du plugin (pas via les commandes
/mcp)
.mcp.json à la racine du plugin :
plugin.json :
- Cycle de vie automatique : Au démarrage de la session, les serveurs des plugins activés se connectent automatiquement. Si vous activez ou désactivez un plugin pendant une session, exécutez
/reload-pluginspour connecter ou déconnecter ses serveurs MCP - Variables d’environnement : utilisez
${CLAUDE_PLUGIN_ROOT}pour les fichiers du plugin groupés,${CLAUDE_PLUGIN_DATA}pour l’état persistant qui survit aux mises à jour du plugin, et${CLAUDE_PROJECT_DIR}pour la racine du projet stable - Accès aux variables d’environnement utilisateur : Accès aux mêmes variables d’environnement que les serveurs configurés manuellement
- Types de transport multiples : Support des transports stdio, SSE et HTTP (le support des transports peut varier selon le serveur)
- Distribution groupée : Outils et serveurs emballés ensemble
- Configuration automatique : Aucune configuration MCP manuelle nécessaire
- Cohérence d’équipe : Tout le monde obtient les mêmes outils lorsque le plugin est installé
Portées d’installation MCP
Les serveurs MCP peuvent être configurés à trois portées différentes. La portée que vous choisissez contrôle les projets dans lesquels le serveur se charge et si la configuration est partagée avec votre équipe. Les administrateurs peuvent également déployer des serveurs au niveau de l’entreprise via la configuration gérée.| Portée | Se charge dans | Partagé avec l’équipe | Stocké dans |
|---|---|---|---|
| Local | Projet actuel uniquement | Non | ~/.claude.json |
| Projet | Projet actuel uniquement | Oui, via le contrôle de version | .mcp.json à la racine du projet |
| Utilisateur | Tous vos projets | Non | ~/.claude.json |
Portée locale
La portée locale est la portée par défaut. Un serveur à portée locale se charge uniquement dans le projet où vous l’avez ajouté et reste privé pour vous. Claude Code le stocke dans~/.claude.json sous le chemin de ce projet, donc le même serveur n’apparaîtra pas dans vos autres projets. Utilisez la portée locale pour les serveurs de développement personnels, les configurations expérimentales ou les serveurs avec des identifiants que vous ne voulez pas dans le contrôle de version.
Le terme « portée locale » pour les serveurs MCP diffère des paramètres locaux généraux. Les serveurs MCP à portée locale sont stockés dans
~/.claude.json (votre répertoire personnel), tandis que les paramètres locaux généraux utilisent .claude/settings.local.json (dans le répertoire du projet). Consultez Paramètres pour plus de détails sur les emplacements des fichiers de paramètres.~/.claude.json. L’exemple ci-dessous montre le résultat lorsque vous l’exécutez à partir de /path/to/your/project :
Portée du projet
Les serveurs à portée de projet permettent la collaboration d’équipe en stockant les configurations dans un fichier.mcp.json à la racine de votre projet. Ce fichier est conçu pour être archivé dans le contrôle de version, garantissant que tous les membres de l’équipe ont accès aux mêmes outils et services MCP. Lorsque vous ajoutez un serveur à portée de projet, Claude Code crée ou met à jour automatiquement ce fichier avec la structure de configuration appropriée.
.mcp.json résultant suit un format standardisé :
.mcp.json. Si vous devez réinitialiser ces choix d’approbation, utilisez la commande claude mcp reset-project-choices.
Portée utilisateur
Les serveurs à portée utilisateur sont stockés dans~/.claude.json et offrent une accessibilité inter-projets, les rendant disponibles dans tous les projets de votre machine tout en restant privés pour votre compte utilisateur. Cette portée fonctionne bien pour les serveurs utilitaires personnels, les outils de développement ou les services que vous utilisez fréquemment dans différents projets.
Hiérarchie de portée et précédence
Lorsque le même serveur est défini à plus d’un endroit, Claude Code s’y connecte une fois, en utilisant la définition de la source avec la plus haute priorité :- Portée locale
- Portée du projet
- Portée utilisateur
- Serveurs fournis par les plugins
- Connecteurs claude.ai
Expansion des variables d’environnement dans .mcp.json
Claude Code supporte l’expansion des variables d’environnement dans les fichiers .mcp.json, permettant aux équipes de partager des configurations tout en maintenant la flexibilité pour les chemins spécifiques à la machine et les valeurs sensibles comme les clés API.
Syntaxe supportée :
${VAR}- Se développe à la valeur de la variable d’environnementVAR${VAR:-default}- Se développe àVARsi défini, sinon utilisedefault
command- Le chemin de l’exécutable du serveurargs- Arguments de la ligne de commandeenv- Variables d’environnement passées au serveururl- Pour les types de serveur HTTPheaders- Pour l’authentification du serveur HTTP
Exemples pratiques
Exemple : Surveiller les erreurs avec Sentry
Exemple : Se connecter à GitHub pour les révisions de code
Le serveur MCP distant de GitHub s’authentifie avec un jeton d’accès personnel GitHub transmis en tant qu’en-tête. Pour en obtenir un, ouvrez vos paramètres de jeton GitHub, générez un nouveau jeton à granularité fine avec accès aux référentiels avec lesquels vous souhaitez que Claude travaille, puis ajoutez le serveur :Exemple : Interroger votre base de données PostgreSQL
S’authentifier auprès des serveurs MCP distants
De nombreux serveurs MCP basés sur le cloud nécessitent une authentification. Claude Code supporte OAuth 2.0 pour les connexions sécurisées. Claude Code marque un serveur distant comme nécessitant une authentification lorsque le serveur répond avec401 Unauthorized et un en-tête WWW-Authenticate pointant vers son serveur d’autorisation. Tout serveur personnalisé qui retourne cette réponse obtient le même flux d’authentification /mcp que tout autre serveur distant.
Utiliser un port de rappel OAuth fixe
Certains serveurs MCP nécessitent un URI de redirection spécifique enregistré à l’avance. Par défaut, Claude Code choisit un port disponible aléatoire pour le rappel OAuth. Utilisez--callback-port pour fixer le port afin qu’il corresponde à un URI de redirection pré-enregistré de la forme http://localhost:PORT/callback.
Vous pouvez utiliser --callback-port seul (avec l’enregistrement dynamique du client) ou ensemble avec --client-id (avec les identifiants pré-configurés).
Utiliser les identifiants OAuth pré-configurés
Certains serveurs MCP ne supportent pas la configuration OAuth automatique via l’enregistrement dynamique du client. Si vous voyez une erreur comme « Incompatible auth server: does not support dynamic client registration », le serveur nécessite des identifiants pré-configurés. Claude Code supporte également les serveurs qui utilisent un document de métadonnées d’ID client (CIMD) au lieu de l’enregistrement dynamique du client, et les découvre automatiquement. Si la découverte automatique échoue, enregistrez d’abord une application OAuth via le portail des développeurs du serveur, puis fournissez les identifiants lors de l’ajout du serveur.Enregistrer une application OAuth auprès du serveur
Créez une application via le portail des développeurs du serveur et notez votre ID client et votre secret client.De nombreux serveurs nécessitent également un URI de redirection. Si c’est le cas, choisissez un port et enregistrez un URI de redirection au format
http://localhost:PORT/callback. Utilisez ce même port avec --callback-port à l’étape suivante.Ajouter le serveur avec vos identifiants
Choisissez l’une des méthodes suivantes. Le port utilisé pour
--callback-port peut être n’importe quel port disponible. Il doit simplement correspondre à l’URI de redirection que vous avez enregistré à l’étape précédente.- claude mcp add
- claude mcp add-json
- claude mcp add-json (port de rappel uniquement)
- CI / variable d'environnement
Utilisez
--client-id pour passer l’ID client de votre application. Le drapeau --client-secret demande le secret avec une entrée masquée :Remplacer la découverte des métadonnées OAuth
Pointez Claude Code vers une URL de métadonnées spécifique du serveur d’autorisation OAuth pour contourner la chaîne de découverte par défaut. DéfinissezauthServerMetadataUrl lorsque les points de terminaison standard du serveur MCP génèrent des erreurs, ou lorsque vous souhaitez acheminer la découverte via un proxy interne. Par défaut, Claude Code vérifie d’abord les métadonnées de ressource protégée RFC 9728 à /.well-known/oauth-protected-resource, puis revient aux métadonnées du serveur d’autorisation RFC 8414 à /.well-known/oauth-authorization-server.
Définissez authServerMetadataUrl dans l’objet oauth de la configuration de votre serveur dans .mcp.json :
https://. authServerMetadataUrl nécessite Claude Code v2.1.64 ou ultérieur. Les scopes_supported de l’URL des métadonnées remplacent les portées que le serveur en amont annonce.
Restreindre les portées OAuth
Définissezoauth.scopes pour épingler les portées que Claude Code demande pendant le flux d’autorisation. C’est la façon supportée de restreindre un serveur MCP à un sous-ensemble approuvé par l’équipe de sécurité lorsque le serveur d’autorisation en amont annonce plus de portées que vous ne souhaitez accorder. La valeur est une seule chaîne séparée par des espaces, correspondant au format du paramètre scope dans RFC 6749 §3.3.
oauth.scopes a la priorité sur authServerMetadataUrl et les portées que le serveur découvre à /.well-known. Laissez-le non défini pour laisser le serveur MCP déterminer l’ensemble de portées demandées.
Si le serveur d’autorisation annonce offline_access dans scopes_supported, Claude Code l’ajoute aux portées épinglées afin que le jeton d’accès puisse être actualisé sans une nouvelle connexion au navigateur.
Si le serveur retourne ultérieurement un 403 insufficient_scope pour un appel d’outil, Claude Code se réauthentifie avec les mêmes portées épinglées. Élargissez oauth.scopes lorsqu’un outil dont vous avez besoin nécessite une portée en dehors de l’épingle.
Utiliser des en-têtes dynamiques pour l’authentification personnalisée
Si votre serveur MCP utilise un schéma d’authentification autre que OAuth (tel que Kerberos, jetons de courte durée ou un SSO interne), utilisezheadersHelper pour générer des en-têtes de requête au moment de la connexion. Claude Code exécute la commande et fusionne sa sortie dans les en-têtes de connexion.
- La commande doit écrire un objet JSON de paires clé-valeur de chaîne sur stdout
- La commande s’exécute dans un shell avec un délai d’expiration de 10 secondes
- Les en-têtes dynamiques remplacent tous les
headersstatiques portant le même nom
| Variable | Valeur |
|---|---|
CLAUDE_CODE_MCP_SERVER_NAME | le nom du serveur MCP |
CLAUDE_CODE_MCP_SERVER_URL | l’URL du serveur MCP |
headersHelper exécute des commandes shell arbitraires. Lorsqu’il est défini à portée de projet ou locale, il ne s’exécute qu’après que vous ayez accepté la boîte de dialogue de confiance de l’espace de travail.Ajouter des serveurs MCP à partir de la configuration JSON
Si vous avez une configuration JSON pour un serveur MCP, vous pouvez l’ajouter directement :Importer les serveurs MCP à partir de Claude Desktop
Si vous avez déjà configuré des serveurs MCP dans Claude Desktop, vous pouvez les importer :Sélectionner les serveurs à importer
Après avoir exécuté la commande, vous verrez une boîte de dialogue interactive qui vous permet de sélectionner les serveurs que vous souhaitez importer.
Utiliser les serveurs MCP à partir de Claude.ai
Si vous vous êtes connecté à Claude Code avec un compte Claude.ai, les serveurs MCP que vous avez ajoutés dans Claude.ai sont automatiquement disponibles dans Claude Code :Configurer les serveurs MCP dans Claude.ai
Ajoutez les serveurs à claude.ai/customize/connectors. Sur les plans Team et Enterprise, seuls les administrateurs peuvent ajouter des serveurs.
/mcp répertorie le connecteur comme masqué et montre comment supprimer le doublon si vous préférez utiliser le connecteur.
Pour désactiver les serveurs MCP de Claude.ai dans Claude Code, définissez la variable d’environnement ENABLE_CLAUDEAI_MCP_SERVERS sur false :
Utiliser Claude Code comme serveur MCP
Vous pouvez utiliser Claude Code lui-même comme serveur MCP auquel d’autres applications peuvent se connecter :Limites de sortie MCP et avertissements
Lorsque les outils MCP produisent de grandes sorties, Claude Code aide à gérer l’utilisation des jetons pour éviter de surcharger votre contexte de conversation :- Seuil d’avertissement de sortie : Claude Code affiche un avertissement lorsque la sortie de tout outil MCP dépasse 10 000 jetons
- Limite configurable : vous pouvez ajuster le nombre maximum de jetons de sortie MCP autorisés en utilisant la variable d’environnement
MAX_MCP_OUTPUT_TOKENS - Limite par défaut : la limite maximale par défaut est de 25 000 jetons
- Portée : la variable d’environnement s’applique aux outils qui ne déclarent pas leur propre limite. Les outils qui définissent
anthropic/maxResultSizeCharsutilisent cette valeur à la place pour le contenu texte, indépendamment de ce queMAX_MCP_OUTPUT_TOKENSest défini. Les outils qui retournent des données d’image sont toujours soumis àMAX_MCP_OUTPUT_TOKENS
- Interrogent de grands ensembles de données ou des bases de données
- Génèrent des rapports ou des documentations détaillés
- Traitent des fichiers journaux ou des informations de débogage étendus
Augmenter la limite pour un outil spécifique
Si vous créez un serveur MCP, vous pouvez permettre aux outils individuels de retourner des résultats plus grands que le seuil par défaut de persistance sur disque en définissant_meta["anthropic/maxResultSizeChars"] dans l’entrée de l’outil dans la réponse tools/list. Claude Code augmente le seuil de cet outil à la valeur annotée, jusqu’à un plafond dur de 500 000 caractères.
Ceci est utile pour les outils qui retournent des sorties intrinsèquement grandes mais nécessaires, telles que les schémas de base de données ou les arbres de fichiers complets. Sans l’annotation, les résultats qui dépassent le seuil par défaut sont persistés sur disque et remplacés par une référence de fichier dans la conversation.
MAX_MCP_OUTPUT_TOKENS pour le contenu texte, donc les utilisateurs n’ont pas besoin d’augmenter la variable d’environnement pour les outils qui la déclarent. Les outils qui retournent des données d’image sont toujours soumis à la limite de jetons.
Répondre aux demandes d’élicitation MCP
Les serveurs MCP peuvent demander une entrée structurée de votre part au cours d’une tâche en utilisant l’élicitation. Lorsqu’un serveur a besoin d’informations qu’il ne peut pas obtenir par lui-même, Claude Code affiche une boîte de dialogue interactive et transmet votre réponse au serveur. Aucune configuration n’est requise de votre côté : les boîtes de dialogue d’élicitation apparaissent automatiquement lorsqu’un serveur les demande. Les serveurs peuvent demander une entrée de deux façons :- Mode formulaire : Claude Code affiche une boîte de dialogue avec des champs de formulaire définis par le serveur (par exemple, une invite de nom d’utilisateur et de mot de passe). Remplissez les champs et soumettez.
- Mode URL : Claude Code ouvre une URL de navigateur pour l’authentification ou l’approbation. Complétez le flux dans le navigateur, puis confirmez dans l’interface de ligne de commande.
Elicitation.
Si vous créez un serveur MCP qui utilise l’élicitation, consultez la spécification d’élicitation MCP pour les détails du protocole et les exemples de schéma.
Utiliser les ressources MCP
Les serveurs MCP peuvent exposer des ressources que vous pouvez référencer en utilisant des mentions @, similaire à la façon dont vous référencez les fichiers.Référencer les ressources MCP
Lister les ressources disponibles
Tapez
@ dans votre prompt pour voir les ressources disponibles de tous les serveurs MCP connectés. Les ressources apparaissent aux côtés des fichiers dans le menu d’autocomplétion.Référencer une ressource spécifique
Utilisez le format
@server:protocol://resource/path pour référencer une ressource :Mettre à l’échelle avec la recherche d’outils MCP
La recherche d’outils maintient l’utilisation du contexte MCP faible en différant les définitions d’outils jusqu’à ce que Claude en ait besoin. Seuls les noms d’outils se chargent au démarrage de la session, donc l’ajout de plus de serveurs MCP a un impact minimal sur votre fenêtre de contexte.Comment cela fonctionne
La recherche d’outils est activée par défaut. Les outils MCP sont différés plutôt que chargés dans le contexte à l’avance, et Claude utilise un outil de recherche pour découvrir les outils pertinents lorsqu’une tâche en a besoin. Seuls les outils que Claude utilise réellement entrent dans le contexte. De votre point de vue, les outils MCP fonctionnent exactement comme avant. Si vous préférez le chargement basé sur un seuil, définissezENABLE_TOOL_SEARCH=auto pour charger les schémas à l’avance lorsqu’ils s’ajustent dans 10 % de la fenêtre de contexte et différer uniquement le débordement. Consultez Configurer la recherche d’outils pour toutes les options.
Pour les auteurs de serveurs MCP
Si vous créez un serveur MCP, le champ des instructions du serveur devient plus utile avec la recherche d’outils activée. Les instructions du serveur aident Claude à comprendre quand rechercher vos outils, similaire à la façon dont les skills fonctionnent. Ajoutez des instructions de serveur claires et descriptives qui expliquent :- Quelle catégorie de tâches vos outils gèrent
- Quand Claude doit rechercher vos outils
- Les capacités clés de votre serveur
Configurer la recherche d’outils
La recherche d’outils est activée par défaut : les outils MCP sont différés et découverts à la demande. Elle est désactivée par défaut sur Vertex AI, qui n’accepte pas l’en-tête bêta de recherche d’outils, et lorsqueANTHROPIC_BASE_URL pointe vers un hôte non-propriétaire, car la plupart des proxies ne transfèrent pas les blocs tool_reference. Si votre proxy transfère les blocs tool_reference, définissez ENABLE_TOOL_SEARCH explicitement pour opter pour. Cette fonctionnalité nécessite des modèles qui supportent les blocs tool_reference : Sonnet 4 et ultérieur, ou Opus 4 et ultérieur. Les modèles Haiku ne supportent pas la recherche d’outils.
Contrôlez le comportement de la recherche d’outils avec la variable d’environnement ENABLE_TOOL_SEARCH :
| Valeur | Comportement |
|---|---|
| (non défini) | Tous les outils MCP différés et chargés à la demande. Revient au chargement à l’avance sur Vertex AI ou lorsque ANTHROPIC_BASE_URL est un hôte non-propriétaire |
true | Tous les outils MCP différés. Claude Code envoie l’en-tête bêta même sur Vertex AI et via les proxies. Les demandes échouent si le backend ne supporte pas les blocs tool_reference |
auto | Mode seuil : les outils se chargent à l’avance s’ils s’ajustent dans 10 % de la fenêtre de contexte, différés sinon |
auto:<N> | Mode seuil avec un pourcentage personnalisé, où <N> est 0-100 (par exemple, auto:5 pour 5 %) |
false | Tous les outils MCP chargés à l’avance, pas de différé |
env de votre settings.json.
Vous pouvez également désactiver l’outil ToolSearch spécifiquement :
Exempter un serveur du différé
Si les outils d’un serveur doivent toujours être visibles pour Claude sans une étape de recherche, définissezalwaysLoad à true dans la configuration de ce serveur. Chaque outil de ce serveur se charge alors dans le contexte au démarrage de la session indépendamment du paramètre ENABLE_TOOL_SEARCH. Utilisez ceci pour un petit nombre d’outils que Claude doit utiliser à chaque tour, car chaque outil à l’avance consomme du contexte qui serait autrement disponible pour votre conversation.
L’entrée .mcp.json suivante exempte un serveur HTTP tout en laissant les autres serveurs différés :
alwaysLoad est disponible sur tous les types de serveurs et nécessite Claude Code v2.1.121 ou ultérieur. Un serveur MCP peut également marquer les outils individuels comme toujours chargés en incluant "anthropic/alwaysLoad": true dans l’objet _meta de l’outil, ce qui a le même effet pour cet outil uniquement.
La définition de alwaysLoad: true bloque également le démarrage jusqu’à ce que le serveur se connecte, limité au délai d’expiration de connexion standard de 5 secondes. Cela s’applique même lorsque MCP_CONNECTION_NONBLOCKING=1 est défini, car les outils doivent être présents lors de la construction de la première invite. Les autres serveurs se connectent toujours en arrière-plan lorsque le mode non-bloquant est activé.
Utiliser les prompts MCP comme commandes
Les serveurs MCP peuvent exposer des prompts qui deviennent disponibles en tant que commandes dans Claude Code.Exécuter les prompts MCP
Découvrir les prompts disponibles
Tapez
/ pour voir toutes les commandes disponibles, y compris celles des serveurs MCP. Les prompts MCP apparaissent au format /mcp__servername__promptname.Configuration MCP gérée
Pour les organisations qui ont besoin d’un contrôle centralisé sur les serveurs MCP, Claude Code supporte deux options de configuration :- Contrôle exclusif avec
managed-mcp.json: Déployer un ensemble fixe de serveurs MCP que les utilisateurs ne peuvent pas modifier ou étendre - Contrôle basé sur les politiques avec listes blanches/noires : Permettre aux utilisateurs d’ajouter leurs propres serveurs, mais restreindre lesquels sont autorisés
- Contrôler les serveurs MCP auxquels les employés peuvent accéder : Déployer un ensemble standardisé de serveurs MCP approuvés dans toute l’organisation
- Empêcher les serveurs MCP non autorisés : Restreindre les utilisateurs d’ajouter des serveurs MCP non approuvés
- Désactiver complètement MCP : Supprimer complètement la fonctionnalité MCP si nécessaire
Option 1 : Contrôle exclusif avec managed-mcp.json
Lorsque vous déployez un fichiermanaged-mcp.json, il prend le contrôle exclusif de tous les serveurs MCP. Les utilisateurs ne peuvent pas ajouter, modifier ou utiliser d’autres serveurs MCP que ceux définis dans ce fichier. C’est l’approche la plus simple pour les organisations qui veulent un contrôle complet.
Les administrateurs système déploient le fichier de configuration dans un répertoire à l’échelle du système :
- macOS :
/Library/Application Support/ClaudeCode/managed-mcp.json - Linux et WSL :
/etc/claude-code/managed-mcp.json - Windows :
C:\Program Files\ClaudeCode\managed-mcp.json
Ce sont des chemins à l’échelle du système (pas des répertoires personnels comme
~/Library/...) qui nécessitent des privilèges d’administrateur. Ils sont conçus pour être déployés par les administrateurs informatiques.managed-mcp.json utilise le même format qu’un fichier .mcp.json standard :
Option 2 : Contrôle basé sur les politiques avec listes blanches et noires
Au lieu de prendre le contrôle exclusif, les administrateurs peuvent permettre aux utilisateurs de configurer leurs propres serveurs MCP tout en appliquant des restrictions sur les serveurs autorisés. Cette approche utiliseallowedMcpServers et deniedMcpServers dans le fichier de paramètres gérés.
Choisir entre les options : Utilisez l’option 1 (
managed-mcp.json) lorsque vous souhaitez déployer un ensemble fixe de serveurs sans personnalisation utilisateur. Utilisez l’option 2 (listes blanches/noires) lorsque vous souhaitez permettre aux utilisateurs d’ajouter leurs propres serveurs dans le respect des contraintes de politique.Options de restriction
Chaque entrée dans la liste blanche ou noire peut restreindre les serveurs de trois façons :- Par nom de serveur (
serverName) : Correspond au nom configuré du serveur - Par commande (
serverCommand) : Correspond à la commande exacte et aux arguments utilisés pour démarrer les serveurs stdio - Par modèle d’URL (
serverUrl) : Correspond aux URL des serveurs distants avec support des caractères génériques
serverName, serverCommand ou serverUrl.
Exemple de configuration
Comment fonctionnent les restrictions basées sur les commandes
Correspondance exacte :- Les tableaux de commandes doivent correspondre exactement - à la fois la commande et tous les arguments dans le bon ordre
- Exemple :
["npx", "-y", "server"]ne correspondra PAS à["npx", "server"]ou["npx", "-y", "server", "--flag"]
- Lorsque la liste blanche contient n’importe quelle entrée
serverCommand, les serveurs stdio doivent correspondre à l’une de ces commandes - Les serveurs stdio ne peuvent pas passer par le nom seul lorsque des restrictions de commande sont présentes
- Cela garantit que les administrateurs peuvent appliquer les commandes autorisées à s’exécuter
- Les serveurs distants (HTTP, SSE, WebSocket) utilisent la correspondance basée sur l’URL lorsque des entrées
serverUrlexistent dans la liste blanche - Si aucune entrée d’URL n’existe, les serveurs distants reviennent à la correspondance basée sur le nom
- Les restrictions de commande ne s’appliquent pas aux serveurs distants
Comment fonctionnent les restrictions basées sur l’URL
Les modèles d’URL supportent les caractères génériques en utilisant* pour correspondre à n’importe quelle séquence de caractères. Ceci est utile pour autoriser des domaines ou des sous-domaines entiers.
Exemples de caractères génériques :
https://mcp.company.com/*- Autoriser tous les chemins sur un domaine spécifiquehttps://*.example.com/*- Autoriser n’importe quel sous-domaine de example.comhttp://localhost:*/*- Autoriser n’importe quel port sur localhost
*://Mcp.Example.com/* correspond à https://mcp.example.com/api, et https://mcp.example.com. est traité de la même manière que https://mcp.example.com. Les schémas et les chemins restent sensibles à la casse.
Comportement du serveur distant :
- Lorsque la liste blanche contient n’importe quelle entrée
serverUrl, les serveurs distants doivent correspondre à l’un de ces modèles d’URL - Les serveurs distants ne peuvent pas passer par le nom seul lorsque des restrictions d’URL sont présentes
- Cela garantit que les administrateurs peuvent appliquer les points de terminaison distants autorisés
Exemple : Liste blanche URL uniquement
Exemple : Liste blanche URL uniquement
- Serveur HTTP à
https://mcp.company.com/api: ✅ Autorisé (correspond au modèle d’URL) - Serveur HTTP à
https://api.internal.corp/mcp: ✅ Autorisé (correspond au sous-domaine générique) - Serveur HTTP à
https://external.com/mcp: ❌ Bloqué (ne correspond à aucun modèle d’URL) - Serveur stdio avec n’importe quelle commande : ❌ Bloqué (aucune entrée de nom ou de commande à correspondre)
Exemple : Liste blanche commande uniquement
Exemple : Liste blanche commande uniquement
- Serveur stdio avec
["npx", "-y", "approved-package"]: ✅ Autorisé (correspond à la commande) - Serveur stdio avec
["node", "server.js"]: ❌ Bloqué (ne correspond pas à la commande) - Serveur HTTP nommé « my-api » : ❌ Bloqué (aucune entrée de nom à correspondre)
Exemple : Liste blanche mixte nom et commande
Exemple : Liste blanche mixte nom et commande
- Serveur stdio nommé « local-tool » avec
["npx", "-y", "approved-package"]: ✅ Autorisé (correspond à la commande) - Serveur stdio nommé « local-tool » avec
["node", "server.js"]: ❌ Bloqué (les entrées de commande existent mais ne correspondent pas) - Serveur stdio nommé « github » avec
["node", "server.js"]: ❌ Bloqué (les serveurs stdio doivent correspondre aux commandes lorsque les entrées de commande existent) - Serveur HTTP nommé « github » : ✅ Autorisé (correspond au nom)
- Serveur HTTP nommé « other-api » : ❌ Bloqué (le nom ne correspond pas)
Exemple : Liste blanche nom uniquement
Exemple : Liste blanche nom uniquement
- Serveur stdio nommé « github » avec n’importe quelle commande : ✅ Autorisé (aucune restriction de commande)
- Serveur stdio nommé « internal-tool » avec n’importe quelle commande : ✅ Autorisé (aucune restriction de commande)
- Serveur HTTP nommé « github » : ✅ Autorisé (correspond au nom)
- N’importe quel serveur nommé « other » : ❌ Bloqué (le nom ne correspond pas)
Comportement de la liste blanche (allowedMcpServers)
undefined(par défaut) : Aucune restriction - les utilisateurs peuvent configurer n’importe quel serveur MCP- Tableau vide
[]: Verrouillage complet - les utilisateurs ne peuvent configurer aucun serveur MCP - Liste d’entrées : Les utilisateurs ne peuvent configurer que les serveurs qui correspondent par nom, commande ou modèle d’URL
Comportement de la liste noire (deniedMcpServers)
undefined(par défaut) : Aucun serveur n’est bloqué- Tableau vide
[]: Aucun serveur n’est bloqué - Liste d’entrées : Les serveurs spécifiés sont explicitement bloqués dans toutes les portées
Notes importantes
- L’option 1 et l’option 2 peuvent être combinées : Si
managed-mcp.jsonexiste, il a le contrôle exclusif et les utilisateurs ne peuvent pas ajouter de serveurs. Les listes blanches/noires s’appliquent toujours aux serveurs gérés eux-mêmes. - La liste noire a une précédence absolue : Si un serveur correspond à une entrée de liste noire (par nom, commande ou URL), il sera bloqué même s’il est sur la liste blanche
- Les restrictions basées sur le nom, la commande et l’URL fonctionnent ensemble : un serveur passe s’il correspond à soit une entrée de nom, une entrée de commande, ou un modèle d’URL (sauf s’il est bloqué par la liste noire)
Lors de l’utilisation de
managed-mcp.json : Les utilisateurs ne peuvent pas ajouter de serveurs MCP via claude mcp add ou les fichiers de configuration. Les paramètres allowedMcpServers et deniedMcpServers s’appliquent toujours pour filtrer les serveurs gérés qui sont réellement chargés.