Qué puede hacer con MCP
Con servidores MCP conectados, puede pedirle a Claude Code que:- Implemente características desde rastreadores de problemas: “Agregue la característica descrita en el problema JIRA ENG-4521 y cree un PR en GitHub.”
- Analice datos de monitoreo: “Verifique Sentry y Statsig para verificar el uso de la característica descrita en ENG-4521.”
- Consulte bases de datos: “Encuentre correos electrónicos de 10 usuarios aleatorios que utilizaron la característica ENG-4521, basándose en nuestra base de datos PostgreSQL.”
- Integre diseños: “Actualice nuestra plantilla de correo electrónico estándar basándose en los nuevos diseños de Figma que se publicaron en Slack”
- Automatice flujos de trabajo: “Cree borradores de Gmail invitando a estos 10 usuarios a una sesión de retroalimentación sobre la nueva característica.”
- Reaccione a eventos externos: Un servidor MCP también puede actuar como un canal que envía mensajes a su sesión, para que Claude reaccione a mensajes de Telegram, chats de Discord o eventos de webhook mientras está fuera.
Buscar y crear servidores MCP
Explore conectores revisados en el Directorio de Anthropic. Los conectores del Directorio utilizan la misma infraestructura MCP que Claude Code, por lo que puede agregar cualquier servidor remoto listado allí conclaude mcp add.
Para crear su propio servidor, consulte la guía del servidor MCP para los fundamentos del protocolo y la documentación de construcción de conectores de Claude para autenticación, pruebas y envío al Directorio.
También puede hacer que Claude cree un servidor para usted con el plugin oficial mcp-server-dev.
Instalar el plugin
En una sesión de Claude Code, ejecute:Si Claude Code informa que el marketplace no se encuentra, ejecute
/plugin marketplace add anthropics/claude-plugins-official primero, luego reintente la instalación. Una vez instalado, ejecute /reload-plugins para activarlo en la sesión actual.Instalación de servidores MCP
Los servidores MCP se pueden configurar de varias formas según sus necesidades:Opción 1: Agregar un servidor HTTP remoto
Los servidores HTTP son la opción recomendada para conectarse a servidores MCP remotos. Este es el transporte más ampliamente soportado para servicios basados en la nube..mcp.json, ~/.claude.json, o claude mcp add-json, el campo type acepta streamable-http como un alias para http. La especificación de MCP utiliza el nombre streamable-http para este transporte, por lo que las configuraciones copiadas de la documentación del servidor funcionan sin modificación.
Opción 2: Agregar un servidor SSE remoto
Opción 3: Agregar un servidor stdio local
Los servidores stdio se ejecutan como procesos locales en su máquina. Son ideales para herramientas que necesitan acceso directo al sistema o scripts personalizados. Claude Code estableceCLAUDE_PROJECT_DIR en el entorno del servidor generado a la raíz del proyecto, por lo que su servidor puede resolver rutas relativas al proyecto sin depender del directorio de trabajo. Este es el mismo directorio que los hooks reciben en su variable CLAUDE_PROJECT_DIR. Léalo desde dentro de su proceso de servidor, por ejemplo process.env.CLAUDE_PROJECT_DIR en Node o os.environ["CLAUDE_PROJECT_DIR"] en Python.
Su servidor también puede llamar a la solicitud MCP roots/list, que devuelve el directorio desde el cual se lanzó Claude Code.
Esta variable se establece en el entorno del servidor, no en el entorno propio de Claude Code, por lo que hacer referencia a ella mediante la expansión ${VAR} en un archivo .mcp.json con alcance de proyecto o usuario en command o args requiere un valor predeterminado como ${CLAUDE_PROJECT_DIR:-.}. Las configuraciones MCP proporcionadas por plugins sustituyen ${CLAUDE_PROJECT_DIR} directamente y no necesitan el valor predeterminado.
Importante: Separar argumentos del servidor con
--Para servidores stdio, el -- (doble guión) separa las opciones propias de Claude, como --transport, --env y --scope, del comando y los argumentos que ejecutan el servidor. Todo lo que viene después de -- se pasa al servidor sin modificar.Por ejemplo:claude mcp add --transport stdio myserver -- npx server→ ejecutanpx serverclaude mcp add --env KEY=value --transport stdio myserver -- python server.py --port 8080→ ejecutapython server.py --port 8080conKEY=valueen el entorno
--, Claude Code intentaría analizar las banderas del servidor, como --port arriba, como sus propias opciones.--env acepta múltiples pares KEY=value. Si el nombre del servidor viene directamente después de --env, la CLI lee el nombre como otro par y lo rechaza, por lo que coloque al menos otra opción entre --env y el nombre del servidor, como en los ejemplos anteriores.Opción 4: Agregar un servidor WebSocket remoto
Los servidores WebSocket mantienen una conexión bidireccional persistente, que es adecuada para servidores MCP remotos que envían eventos a Claude sin ser solicitados. Use HTTP en su lugar cuando su servidor solo responda a solicitudes, ya que HTTP admite OAuth y la banderaclaude mcp add --transport, mientras que WebSocket no admite ninguno de los dos.
Configure servidores WebSocket en .mcp.json o con claude mcp add-json:
type: "ws" acepta los mismos campos url, headers, headersHelper, timeout y alwaysLoad que http. La autenticación es solo por encabezado, por lo que pase un token estático en headers o genere uno en el momento de la conexión con headersHelper. La bandera claude mcp add --transport no acepta ws.
Gestión de sus servidores
Una vez configurados, puede gestionar sus servidores MCP con estos comandos:.mcp.json que están esperando su aprobación aparecen en claude mcp list como ⏸ Pending approval. Ejecute claude de forma interactiva para revisar y aprobar. claude mcp get <name> muestra servidores pendientes como ⏸ Pending approval y servidores rechazados como ✗ Rejected.
A partir de v2.1.196, claude mcp list y claude mcp get leen aprobaciones de .mcp.json solo desde archivos de configuración que no están comprometidos en el repositorio hasta que confíe en el espacio de trabajo ejecutando claude en él y aceptando el diálogo de confianza del espacio de trabajo. Un repositorio clonado no puede aprobar sus propios servidores: enableAllProjectMcpServers o enabledMcpjsonServers comprometido en el archivo .claude/settings.json del proyecto se ignora en una carpeta no confiable, y el servidor permanece en ⏸ Pending approval en lugar de estar conectado y verificado de salud.
Las aprobaciones de estas fuentes aún se aplican en una carpeta no confiable:
- su archivo
~/.claude/settings.jsondel usuario - configuración gestionada
- configuración pasada con
--settings .claude/settings.local.json, siempre que git no lo rastree
disabledMcpjsonServers en cualquier archivo de configuración aún rechaza el servidor.
El panel /mcp muestra el recuento de herramientas junto a cada servidor conectado e indica los servidores que anuncian la capacidad de herramientas pero no exponen ninguna herramienta.
Si su solicitud necesita herramientas de un servidor que aún se está conectando en segundo plano, Claude espera a que ese servidor continúe. Con búsqueda de herramientas habilitada, que es la predeterminada, la espera ocurre dentro de la llamada ToolSearch. En configuraciones sin búsqueda de herramientas, como Vertex AI, un ANTHROPIC_BASE_URL personalizado, o ENABLE_TOOL_SEARCH=false, Claude utiliza la herramienta WaitForMcpServers en su lugar.
El nombre del servidor workspace está reservado para uso interno. Si su configuración define un servidor con ese nombre, Claude Code lo omite al cargar y muestra una advertencia pidiéndole que lo renombre.
Actualizaciones dinámicas de herramientas
Claude Code admite notificacioneslist_changed de MCP, permitiendo que los servidores MCP actualicen dinámicamente sus herramientas disponibles, indicaciones y recursos sin requerir que se desconecte y reconecte. Cuando un servidor MCP envía una notificación list_changed, Claude Code actualiza automáticamente las capacidades disponibles de ese servidor.
Reconexión automática
Si un servidor HTTP o SSE se desconecta durante la sesión, Claude Code se reconecta automáticamente con retroceso exponencial: hasta cinco intentos, comenzando con un retraso de un segundo y duplicándose cada vez. El servidor aparece como pendiente en/mcp mientras la reconexión está en progreso. Después de cinco intentos fallidos, el servidor se marca como fallido y puede reintentar manualmente desde /mcp. Los servidores stdio son procesos locales y no se reconectan automáticamente.
El mismo retroceso se aplica cuando un servidor HTTP o SSE falla su conexión inicial al iniciar. A partir de v2.1.121, Claude Code reintenta la conexión inicial hasta tres veces en errores transitorios como una respuesta 5xx, una conexión rechazada o un tiempo de espera agotado, luego marca el servidor como fallido si aún no puede conectarse. Los errores de autenticación y no encontrado no se reintentan porque requieren un cambio de configuración para resolverse.
A partir de v2.1.191, las solicitudes de descubrimiento de capacidades que se ejecutan después de una conexión exitosa, como tools/list, prompts/list y resources/list, también reintentan errores de red transitorios y del servidor hasta tres veces con retroceso corto. Los errores de autenticación, respuestas 4xx y tiempos de espera de solicitud no se reintentan.
Mensajes push con canales
Un servidor MCP también puede enviar mensajes directamente a su sesión para que Claude pueda reaccionar a eventos externos como resultados de CI, alertas de monitoreo o mensajes de chat. Para habilitar esto, su servidor declara la capacidadclaude/channel y usted la activa con la bandera --channels al iniciar. Vea Canales para usar un canal oficialmente soportado, o Referencia de canales para construir el suyo propio.
El timeout por servidor es un límite de reloj de pared duro por llamada de herramienta, y las notificaciones de progreso del servidor no lo extienden. Los valores por debajo de 1000 se ignoran y caen a MCP_TOOL_TIMEOUT, o a su predeterminado de aproximadamente 28 horas cuando esa variable no está establecida. Antes de v2.1.162, los valores por debajo de 1000 se redondeaban hacia abajo a un segundo en su lugar.
Para servidores HTTP y SSE, el presupuesto de primer byte por solicitud de obtención tiene un mínimo de 60 segundos.
A partir de v2.1.187, una llamada de herramienta a un servidor HTTP remoto, SSE, WebSocket, o conector de claude.ai que no envía respuesta ni notificación de progreso durante 5 minutos se cancela con un error en lugar de esperar el límite de reloj de pared. Establezca la variable de entorno CLAUDE_CODE_MCP_TOOL_IDLE_TIMEOUT en milisegundos para cambiar la ventana de inactividad, o establézcala en 0 para desactivar la verificación. Los servidores stdio son procesos locales y no están sujetos al tiempo de espera de inactividad.
Servidores MCP proporcionados por plugins
Los plugins pueden agrupar servidores MCP, proporcionando automáticamente herramientas e integraciones cuando el plugin está habilitado. Los servidores MCP de plugins funcionan de manera idéntica a los servidores configurados por el usuario. Cómo funcionan los servidores MCP de plugins:- Los plugins definen servidores MCP en
.mcp.jsonen la raíz del plugin o en línea enplugin.json - Cuando un plugin está habilitado, sus servidores MCP se inician automáticamente
- Las herramientas MCP del plugin aparecen junto a las herramientas MCP configuradas manualmente
- Los servidores de plugins se gestionan a través de la instalación de plugins, no mediante comandos
/mcp
.mcp.json en la raíz del plugin:
plugin.json:
- Ciclo de vida automático: Al iniciar la sesión, los servidores de los plugins habilitados se conectan automáticamente. Si habilita o deshabilita un plugin durante una sesión, ejecute
/reload-pluginspara conectar o desconectar sus servidores MCP - Variables de entorno: Use
${CLAUDE_PLUGIN_ROOT}para archivos agrupados en el plugin,${CLAUDE_PLUGIN_DATA}para estado persistente que sobrevive a las actualizaciones de plugins, y${CLAUDE_PROJECT_DIR}para la raíz del proyecto estable - Acceso a variables de entorno del usuario: Acceso a las mismas variables de entorno que los servidores configurados manualmente
- Múltiples tipos de transporte: Soporte para transportes stdio, SSE, HTTP y WebSocket, aunque el soporte de transporte puede variar según el servidor
mcp__plugin_<plugin-name>_<server-name>__<tool-name>, donde cualquier carácter fuera de A-Z, a-z, 0-9, _ y - se reemplaza con _. Para el servidor database-tools agrupado en un plugin llamado my-plugin, una herramienta query es invocable como:
allowed-tools de una skill, o el campo tools de un subagente.
Beneficios de los servidores MCP de plugins:
- Distribución agrupada: Herramientas y servidores empaquetados juntos
- Configuración automática: No se necesita configuración manual de MCP
- Consistencia del equipo: Todos obtienen las mismas herramientas cuando se instala el plugin
Alcances de instalación de MCP
Los servidores MCP se pueden configurar en tres alcances. El alcance que elija controla en qué proyectos se carga el servidor y si la configuración se comparte con su equipo. Los administradores también pueden implementar servidores a nivel empresarial a través de configuración administrada.Alcance local
El alcance local es el predeterminado. Un servidor con alcance local se carga solo en el proyecto donde lo agregó y permanece privado para usted. Claude Code lo almacena en~/.claude.json bajo la ruta de ese proyecto, por lo que el mismo servidor no aparecerá en sus otros proyectos. Use el alcance local para servidores de desarrollo personal, configuraciones experimentales o servidores con credenciales que no desea en el control de versiones.
El término “alcance local” para servidores MCP difiere de la configuración local general. Los servidores MCP con alcance local se almacenan en
~/.claude.json (su directorio de inicio), mientras que la configuración local general usa .claude/settings.local.json (en el directorio del proyecto). Vea Configuración para detalles sobre ubicaciones de archivos de configuración.~/.claude.json. El ejemplo a continuación muestra el resultado cuando lo ejecuta desde /path/to/your/project:
Alcance de proyecto
Los servidores con alcance de proyecto habilitan la colaboración en equipo al almacenar configuraciones en un archivo.mcp.json en el directorio raíz de su proyecto. Este archivo está diseñado para ser verificado en el control de versiones, asegurando que todos los miembros del equipo tengan acceso a las mismas herramientas y servicios MCP. Cuando agrega un servidor con alcance de proyecto, Claude Code crea o actualiza automáticamente este archivo con la estructura de configuración apropiada.
.mcp.json resultante sigue un formato estandarizado:
.mcp.json. Si necesita restablecer estas opciones de aprobación, use el comando claude mcp reset-project-choices.
Alcance de usuario
Los servidores con alcance de usuario se almacenan en~/.claude.json y proporcionan accesibilidad entre proyectos, haciéndolos disponibles en todos los proyectos en su máquina mientras permanecen privados para su cuenta de usuario. Este alcance funciona bien para servidores de utilidad personal, herramientas de desarrollo o servicios que usa frecuentemente en diferentes proyectos.
Jerarquía de alcance y precedencia
Cuando el mismo servidor está definido en más de un lugar, Claude Code se conecta a él una sola vez, usando la definición de la fuente de mayor precedencia. La entrada completa del servidor de esa fuente se utiliza; los campos no se fusionan entre alcances.- Alcance local
- Alcance de proyecto
- Alcance de usuario
- Servidores proporcionados por plugins
- Conectores de claude.ai
Expansión de variables de entorno en .mcp.json
Claude Code admite la expansión de variables de entorno en archivos .mcp.json, permitiendo que los equipos compartan configuraciones mientras mantienen flexibilidad para rutas específicas de máquinas y valores sensibles como claves API.
Sintaxis soportada:
${VAR}: se expande al valor de la variable de entornoVAR${VAR:-default}: se expande aVARsi está establecida, de lo contrario usadefault
command: la ruta del ejecutable del servidorargs: argumentos de línea de comandosenv: variables de entorno pasadas al servidorurl: para tipos de servidor HTTPheaders: para autenticación de servidor HTTP
Ejemplos prácticos
Ejemplo: Monitorear errores con Sentry
Ejemplo: Conectar a GitHub para revisiones de código
El servidor MCP remoto de GitHub se autentica con un token de acceso personal de GitHub pasado como encabezado. Para obtener uno, abra su configuración de token de GitHub, genere un nuevo token de grano fino con acceso a los repositorios con los que desea que Claude trabaje, luego agregue el servidor:Ejemplo: Consultar su base de datos PostgreSQL
Autenticarse con servidores MCP remotos
Muchos servidores MCP basados en la nube requieren autenticación. Claude Code admite OAuth 2.0 para conexiones seguras. Claude Code marca un servidor remoto como que requiere autenticación cuando el servidor responde con401 Unauthorized o 403 Forbidden. Cualquiera de estos códigos de estado marca el servidor en /mcp para que pueda completar el flujo de OAuth.
A partir de v2.1.195, cuando una actualización de token falla porque el servidor rechaza el token de actualización almacenado, Claude Code muestra inmediatamente un aviso que apunta a /mcp. El menú del servidor conectado allí ofrece Re-authenticate, para que pueda iniciar sesión nuevamente antes de que la siguiente llamada de herramienta falle.
Un servidor personalizado que devuelve un encabezado WWW-Authenticate que apunta a su servidor de autorización obtiene el mismo descubrimiento automático que cualquier otro servidor remoto.
A partir de v2.1.193, Claude Code también muestra un aviso de inicio cuando uno o más servidores configurados necesitan autenticación, por lo que no tiene que abrir /mcp para descubrir qué servidores necesitan iniciar sesión.
En modo no interactivo no hay panel /mcp, por lo que Claude Code no puede ejecutar el flujo de OAuth para usted. A partir de v2.1.196, cuando un servidor configurado necesita autenticación durante una ejecución de claude -p o Agent SDK con búsqueda de herramientas habilitada, que es la predeterminada, Claude Code le dice a Claude que las herramientas del servidor no están disponibles hasta que lo autorice. Claude puede entonces nombrar el servidor que necesita iniciar sesión en lugar de responder como si el servidor no estuviera configurado. Complete el inicio de sesión desde una sesión interactiva con /mcp o claude mcp login <name>.
Si configuró headers.Authorization para el servidor y el servidor rechaza ese encabezado, Claude Code reporta la conexión como fallida en lugar de recurrir a OAuth. Verifique que el token sea válido para el punto final de MCP, o elimine el encabezado para usar el flujo de OAuth.
Autenticarse desde la línea de comandos
A partir de v2.1.186,claude mcp login <name> ejecuta el flujo de OAuth de un servidor configurado directamente desde su shell, por lo que no necesita abrir el panel /mcp dentro de una sesión.
claude mcp logout <name>.
A partir de v2.1.191, el comando detecta cuando no hay navegador local disponible, como durante una sesión SSH o en Linux sin un servidor de pantalla, e imprime la URL de autorización en lugar de intentar abrir un navegador. Abra la URL en su máquina local, luego pegue la URL de redireccionamiento completa de la barra de direcciones de su navegador nuevamente en el indicador. El comando necesita una terminal interactiva para el paso de pegado, así que conéctese con ssh -t. Pase --no-browser para forzar el indicador de URL incluso cuando se detecta un navegador local.
Usar un puerto de devolución de llamada OAuth fijo
Algunos servidores MCP requieren un URI de redireccionamiento específico registrado de antemano. De forma predeterminada, Claude Code elige un puerto disponible aleatorio para la devolución de llamada de OAuth. Use--callback-port para fijar el puerto de modo que coincida con un URI de redireccionamiento preregistrado de la forma http://localhost:PORT/callback.
Puede usar --callback-port por sí solo (con registro dinámico de clientes) o junto con --client-id (con credenciales preconfiguradas).
Usar credenciales OAuth preconfiguradas
Algunos servidores MCP no admiten configuración automática de OAuth mediante Registro Dinámico de Clientes. Si ve un error como “Incompatible auth server: does not support dynamic client registration”, el servidor requiere credenciales preconfiguradas. Claude Code también admite servidores que usan un Documento de Metadatos de ID de Cliente (CIMD) en lugar de Registro Dinámico de Clientes, y los descubre automáticamente. Si el descubrimiento automático falla, registre una aplicación OAuth a través del portal de desarrolladores del servidor primero, luego proporcione las credenciales al agregar el servidor.Registrar una aplicación OAuth con el servidor
Cree una aplicación a través del portal de desarrolladores del servidor y anote su ID de cliente y secreto de cliente.Muchos servidores también requieren un URI de redireccionamiento. Si es así, elija un puerto y registre un URI de redireccionamiento en el formato
http://localhost:PORT/callback. Use ese mismo puerto con --callback-port en el siguiente paso.Agregar el servidor con sus credenciales
Elija uno de los siguientes métodos. El puerto utilizado para
--callback-port puede ser cualquier puerto disponible. Solo necesita coincidir con el URI de redireccionamiento que registró en el paso anterior.- claude mcp add
- claude mcp add-json
- claude mcp add-json (solo puerto de devolución de llamada)
- CI / variable de entorno
Use
--client-id para pasar el ID de cliente de su aplicación. La bandera --client-secret solicita el secreto con entrada enmascarada:Anular el descubrimiento de metadatos de OAuth
Apunte Claude Code a una URL de metadatos de servidor de autorización OAuth específica para omitir la cadena de descubrimiento predeterminada. EstablezcaauthServerMetadataUrl cuando los puntos finales estándar del servidor MCP generen errores, o cuando desee enrutar el descubrimiento a través de un proxy interno. De forma predeterminada, Claude Code primero verifica los Metadatos de Recursos Protegidos RFC 9728 en /.well-known/oauth-protected-resource, luego recurre a los metadatos del servidor de autorización RFC 8414 en /.well-known/oauth-authorization-server.
Establezca authServerMetadataUrl en el objeto oauth de la configuración de su servidor en .mcp.json:
https://. authServerMetadataUrl requiere Claude Code v2.1.64 o posterior. Los scopes_supported de la URL de metadatos anulan los alcances que el servidor ascendente anuncia.
Restringir alcances de OAuth
Establezcaoauth.scopes para fijar los alcances que Claude Code solicita durante el flujo de autorización. Esta es la forma soportada de restringir un servidor MCP a un subconjunto aprobado por el equipo de seguridad cuando el servidor de autorización ascendente anuncia más alcances de los que desea otorgar. El valor es una cadena única separada por espacios, que coincide con el formato del parámetro scope en RFC 6749 §3.3.
oauth.scopes tiene precedencia sobre tanto authServerMetadataUrl como los alcances que el servidor descubre en /.well-known. Déjelo sin establecer para permitir que el servidor MCP determine el conjunto de alcances solicitados.
A partir de v2.1.196, cuando oauth.scopes no está establecido, Claude Code solicita el alcance proporcionado por el encabezado WWW-Authenticate del servidor o sus metadatos de recursos protegidos, y no envía ningún parámetro scope cuando ninguno proporciona uno. Ya no solicita el catálogo completo de scopes_supported de los metadatos del servidor de autorización descubiertos automáticamente. Solicitar ese catálogo hizo que los proveedores de identidad que anuncian alcances solo para administrador o de plantilla rechazaran la solicitud de autorización con un error invalid_scope. Los metadatos obtenidos de un authServerMetadataUrl configurado aún proporcionan su scopes_supported como los alcances solicitados.
Si el servidor de autorización anuncia offline_access en scopes_supported, Claude Code lo añade a los alcances fijados para que el token de acceso pueda actualizarse sin un nuevo inicio de sesión en el navegador.
Si el servidor luego devuelve un 403 insufficient_scope para una llamada de herramienta, Claude Code se reautentica con los mismos alcances fijados. Amplíe oauth.scopes cuando una herramienta que necesita requiera un alcance fuera del fijo.
Usar encabezados dinámicos para autenticación personalizada
Si su servidor MCP usa un esquema de autenticación diferente a OAuth, como Kerberos, tokens de corta duración o un SSO interno, useheadersHelper para generar encabezados de solicitud en el momento de la conexión. Claude Code ejecuta el comando y fusiona su salida en los encabezados de conexión.
- El comando debe escribir un objeto JSON de pares clave-valor de cadena en stdout
- El comando se ejecuta en un shell con un tiempo de espera de 10 segundos
- Los encabezados dinámicos anulan cualquier
headersestático con el mismo nombre
401 Unauthorized o 403 Forbidden, Claude Code automáticamente vuelve a ejecutar el ayudante, se reconecta con los encabezados frescos, e intenta la llamada una vez más. Claude Code marca el servidor como que necesita autenticación en /mcp solo si ese reintento también falla.
Claude Code establece estas variables de entorno al ejecutar el ayudante:
| Variable | Valor |
|---|---|
CLAUDE_CODE_MCP_SERVER_NAME | el nombre del servidor MCP |
CLAUDE_CODE_MCP_SERVER_URL | la URL del servidor MCP |
CLAUDE_PLUGIN_ROOT | el directorio raíz del plugin. Se establece solo cuando un plugin proporciona el servidor |
headersHelper relativa se resuelve dentro del directorio del plugin en lugar de contra el directorio de trabajo de la sesión. Requiere Claude Code v2.1.195 o posterior.
headersHelper ejecuta comandos de shell arbitrarios. Cuando se define en alcance de proyecto o local, solo se ejecuta después de que acepte el diálogo de confianza del espacio de trabajo.Agregar servidores MCP desde configuración JSON
Si tiene una configuración JSON para un servidor MCP, puede agregarla directamente:Importar servidores MCP desde Claude Desktop
Si ya ha configurado servidores MCP en Claude Desktop, puede importarlos:Seleccionar qué servidores importar
Después de ejecutar el comando, verá un diálogo interactivo que le permite seleccionar qué servidores desea importar.
Usar servidores MCP desde Claude.ai
Si ha iniciado sesión en Claude Code con una cuenta de Claude.ai, los servidores MCP que ha agregado en Claude.ai están automáticamente disponibles en Claude Code:Configurar servidores MCP en Claude.ai
Agregue servidores en claude.ai/customize/connectors. En planes de Equipo y Empresa, solo los administradores pueden agregar servidores.
Show unused connectors al final de la sección de Claude.ai, por lo que una lista provista por la organización no llena el panel. Seleccione la fila para expandirlos. Un conector en el que inició sesión anteriormente permanece visible incluso cuando actualmente necesita reautenticación.
Los conectores de Claude.ai se obtienen solo cuando su método de autenticación activo es su suscripción a Claude.ai. No se cargan cuando ANTHROPIC_API_KEY, ANTHROPIC_AUTH_TOKEN, apiKeyHelper, o un proveedor de terceros como Bedrock o Vertex está activo, incluso si ejecutó previamente /login. Si /mcp no enumera un conector que agregó, ejecute /status para confirmar qué método de autenticación está activo, desestablezca esa variable de entorno o elimine la configuración apiKeyHelper, luego ejecute /login para seleccionar su cuenta de Claude.ai.
Un servidor que ha agregado en Claude Code tiene precedencia sobre un conector de Claude.ai que apunta a la misma URL. Cuando esto sucede, /mcp enumera el conector como oculto y muestra cómo eliminar el duplicado si prefiere usar el conector.
Algunos conectores alojados por Anthropic, como Microsoft 365, Gmail y Google Calendar, no admiten OAuth local desde Claude Code porque el proveedor de identidad ascendente solo acepta la URL de redirección que registró claude.ai. A partir de v2.1.162, autenticar uno de estos hosts en /mcp muestra un mensaje que lo dirige a conectarlo en Configuración → Conectores en claude.ai en su lugar. Una vez conectado allí, el conector aparece en Claude Code automáticamente.
Desactivar conectores de claude.ai
Para desactivar servidores MCP de Claude.ai en Claude Code, establezcadisableClaudeAiConnectors en true en cualquier ámbito de configuración:
true en cualquier fuente de configuración tiene precedencia. Un archivo .claude/settings.json de proyecto verificado puede optar por no usar conectores en la nube, pero un false a nivel de proyecto no puede volver a habilitar conectores que un true a nivel de usuario o política ha deshabilitado. Los servidores pasados explícitamente a través de --mcp-config no se ven afectados.
También puede establecer la variable de entorno ENABLE_CLAUDEAI_MCP_SERVERS en false, que tiene el mismo efecto para la sesión de shell actual:
deniedMcpServers por nombre o por patrón de URL. Por ejemplo, una entrada serverName de "claude.ai Slack" bloquea el conector de Slack. Para activar o desactivar un conector solo para el proyecto actual, use el panel /mcp.
Estas configuraciones del lado del cliente rigen las sesiones locales de Claude Code. En sesiones de Claude Code en la web, los conectores de claude.ai son aprovisionados por el host remoto y llegan como entradas explícitas de
--mcp-config, por lo que disableClaudeAiConnectors no se aplica allí. Las URL de conectores también se reescriben a través del proxy de sesión, por lo que un patrón serverUrl de deniedMcpServers dirigido a la URL del proveedor no coincidirá. Gestione qué conectores puede usar una sesión en la nube desde la configuración de su organización en claude.ai.Usar Claude Code como servidor MCP
Puede usar Claude Code mismo como servidor MCP al que otras aplicaciones pueden conectarse:Límites de salida de MCP y advertencias
Cuando las herramientas MCP producen salidas grandes, Claude Code ayuda a gestionar el uso de tokens para evitar abrumar el contexto de su conversación:- Umbral de advertencia de salida: Claude Code muestra una advertencia cuando la salida de cualquier herramienta MCP excede 10,000 tokens
- Límite configurable: Puede ajustar los tokens de salida MCP máximos permitidos usando la variable de entorno
MAX_MCP_OUTPUT_TOKENS - Límite predeterminado: El máximo predeterminado es 25,000 tokens
- Alcance: La variable de entorno se aplica a herramientas que no declaran su propio límite. Las herramientas que establecen
anthropic/maxResultSizeCharsusan ese valor en su lugar para contenido de texto, independientemente de lo queMAX_MCP_OUTPUT_TOKENSesté establecido. Las herramientas que devuelven datos de imagen aún están sujetas aMAX_MCP_OUTPUT_TOKENS
- Consultan grandes conjuntos de datos o bases de datos
- Generan reportes o documentación detallados
- Procesan archivos de registro extensos o información de depuración
Aumentar el límite para una herramienta específica
Si está construyendo un servidor MCP, puede permitir que herramientas individuales devuelvan resultados más grandes que el umbral predeterminado de persistencia en disco estableciendo_meta["anthropic/maxResultSizeChars"] en la entrada de la herramienta en la respuesta tools/list. Claude Code aumenta el umbral de esa herramienta al valor anotado, hasta un límite máximo de 500,000 caracteres.
Esto es útil para herramientas que devuelven salidas inherentemente grandes pero necesarias, como esquemas de bases de datos o árboles de archivos completos. Sin la anotación, los resultados que exceden el umbral predeterminado se persisten en disco y se reemplazan con una referencia de archivo en la conversación.
MAX_MCP_OUTPUT_TOKENS para contenido de texto, por lo que los usuarios no necesitan aumentar la variable de entorno para herramientas que la declaran. Las herramientas que devuelven datos de imagen aún están sujetas al límite de tokens.
Responder a solicitudes de elicitación de MCP
Los servidores MCP pueden solicitar entrada estructurada de usted durante una tarea usando elicitación. Cuando un servidor necesita información que no puede obtener por sí solo, Claude Code muestra un diálogo interactivo y pasa su respuesta de vuelta al servidor. No se requiere configuración de su parte: los diálogos de elicitación aparecen automáticamente cuando un servidor los solicita. Los servidores pueden solicitar entrada de dos formas:- Modo de formulario: Claude Code muestra un diálogo con campos de formulario definidos por el servidor (por ejemplo, un indicador de nombre de usuario y contraseña). Complete los campos y envíe.
- Modo de URL: Claude Code abre una URL del navegador para autenticación o aprobación. Complete el flujo en el navegador, luego confirme en la CLI.
Elicitation.
Si está construyendo un servidor MCP que usa elicitación, vea la especificación de elicitación de MCP para detalles de protocolo y ejemplos de esquema.
Usar recursos MCP
Los servidores MCP pueden exponer recursos que puede referenciar usando menciones @, similar a cómo referencia archivos.Referenciar recursos MCP
Listar recursos disponibles
Escriba
@ en su indicación para ver los recursos disponibles de todos los servidores MCP conectados. Los recursos aparecen junto a los archivos en el menú de autocompletado.Referenciar un recurso específico
Use el formato
@server:protocol://resource/path para referenciar un recurso:Escalar con MCP Tool Search
Tool Search mantiene el uso de contexto MCP bajo al diferir las definiciones de herramientas hasta que Claude las necesite. Solo los nombres de herramientas e instrucciones del servidor se cargan al iniciar la sesión, por lo que agregar más servidores MCP tiene un impacto mínimo en su ventana de contexto. Claude Code no impone un límite fijo de herramientas por servidor; el límite práctico es su presupuesto de ventana de contexto.Cómo funciona
Tool Search está habilitado de forma predeterminada. Las herramientas MCP se difieren en lugar de cargarse en el contexto de antemano, y Claude usa una herramienta de búsqueda para descubrir las relevantes cuando una tarea las necesita. Solo las herramientas que Claude realmente usa entran en el contexto. Desde su perspectiva, las herramientas MCP funcionan exactamente como antes. Si prefiere carga basada en umbral, establezcaENABLE_TOOL_SEARCH=auto para cargar esquemas de antemano cuando se ajusten dentro del 10% de la ventana de contexto y diferir solo el desbordamiento. Vea Configurar búsqueda de herramientas para todas las opciones.
Para autores de servidores MCP
Si está construyendo un servidor MCP, el campo de instrucciones del servidor se vuelve más útil con Tool Search habilitado. Las instrucciones del servidor ayudan a Claude a entender cuándo buscar sus herramientas, similar a cómo funcionan las skills. Agregue instrucciones claras y descriptivas del servidor que expliquen:- Qué categoría de tareas manejan sus herramientas
- Cuándo Claude debe buscar sus herramientas
- Capacidades clave que proporciona su servidor
Configurar búsqueda de herramientas
Tool Search está habilitado de forma predeterminada: las herramientas MCP se difieren y se descubren bajo demanda. Claude Code lo desactiva de forma predeterminada en Vertex AI. También se desactiva cuandoANTHROPIC_BASE_URL apunta a un host que no es de primera parte, ya que la mayoría de los proxies no reenvían bloques tool_reference. Establezca ENABLE_TOOL_SEARCH explícitamente para anular cualquiera de estos comportamientos predeterminados.
Tool Search requiere un modelo que admita bloques tool_reference. Los modelos Haiku no lo admiten. En Vertex AI, Tool Search se admite para Claude Sonnet 4.5 y posterior y Claude Opus 4.5 y posterior.
Controle el comportamiento de búsqueda de herramientas con la variable de entorno ENABLE_TOOL_SEARCH:
| Valor | Comportamiento |
|---|---|
| (sin establecer) | Todas las herramientas MCP diferidas y cargadas bajo demanda. Recurre a carga de antemano en Vertex AI o cuando ANTHROPIC_BASE_URL es un host que no es de primera parte |
true | Todas las herramientas MCP diferidas. Claude Code envía el encabezado beta incluso en Vertex AI y a través de proxies. Las solicitudes fallan en modelos de Vertex AI anteriores a Sonnet 4.5 u Opus 4.5, o en proxies que no admiten bloques tool_reference |
auto | Modo de umbral: las herramientas se cargan de antemano si se ajustan dentro del 10% de la ventana de contexto, diferidas de lo contrario |
auto:N | Modo de umbral con un porcentaje personalizado, donde N es 0-100. Por ejemplo, auto:5 para 5% |
false | Todas las herramientas MCP cargadas de antemano, sin diferimiento |
env de settings.json.
También puede desactivar la herramienta ToolSearch específicamente:
Eximir un servidor del diferimiento
Si las herramientas de un servidor deben ser siempre visibles para Claude sin un paso de búsqueda, establezcaalwaysLoad en true en la configuración de ese servidor. Cada herramienta de ese servidor se carga entonces en el contexto al iniciar la sesión independientemente de la configuración ENABLE_TOOL_SEARCH. Use esto para un pequeño número de herramientas que Claude necesita en cada turno, ya que cada herramienta de antemano consume contexto que de otro modo estaría disponible para su conversación.
La siguiente entrada .mcp.json exime un servidor HTTP mientras deja otros servidores diferidos:
alwaysLoad está disponible en todos los tipos de servidor y requiere Claude Code v2.1.121 o posterior. Un servidor MCP también puede marcar herramientas individuales como siempre cargadas incluyendo "anthropic/alwaysLoad": true en el objeto _meta de la herramienta, que tiene el mismo efecto solo para esa herramienta.
Establecer alwaysLoad: true también bloquea el inicio hasta que el servidor se conecte, limitado al tiempo de espera de conexión estándar de 5 segundos. Esto se aplica incluso cuando MCP startup es de otro modo no bloqueante de forma predeterminada, ya que las herramientas deben estar presentes cuando se construye el primer mensaje. Otros servidores aún se conectan en segundo plano.
Usar indicaciones MCP como comandos
Los servidores MCP pueden exponer indicaciones que se vuelven disponibles como comandos en Claude Code.Ejecutar indicaciones MCP
Descubrir indicaciones disponibles
Escriba
/ para ver todos los comandos disponibles, incluyendo los de servidores MCP. Las indicaciones MCP aparecen con el formato /mcp__servername__promptname.Configuración MCP gestionada
Para organizaciones que necesitan control centralizado sobre qué servidores MCP pueden conectar los usuarios, consulte Configuración MCP gestionada. Cubre la implementación de un conjunto de servidores fijo conmanaged-mcp.json, la restricción de servidores con allowedMcpServers y deniedMcpServers, y lo que los usuarios ven cuando un servidor está bloqueado.