Couchbase
oficialInteractúa con los datos almacenados en clústeres de Couchbase usando lenguaje natural.
¿Qué puedes hacer con Couchbase MCP?
- Check cluster health and connectivity — Ask the assistant to verify the cluster is reachable and review running services using
test_cluster_connectionandget_cluster_health_and_services. - Explore the data model — Discover buckets, scopes, and collections with
get_buckets_in_cluster,get_scopes_in_bucket, andget_collections_in_scope, then inspect a collection’s structure viaget_schema_for_collection. - Retrieve and manage documents — Fetch documents by ID with
get_document_by_id, and when write mode is enabled, create, update, or delete documents usingupsert_document_by_id,insert_document_by_id,replace_document_by_id, ordelete_document_by_id. - Run and optimize SQL++ queries — Execute read-only queries with
run_sql_plus_plus_query, review execution plans viaexplain_sql_plus_plus_query, and get index recommendations fromget_index_advisor_recommendations. - Analyze query performance — Identify slow or resource-heavy queries using tools like
get_longest_running_queries,get_most_frequent_queries, andget_queries_using_primary_index.
Documentación
Servidor MCP de Couchbase
El Servidor MCP de Couchbase es un servidor MCP autogestionado que permite a los agentes de IA conectarse e interactuar con datos en clústeres de Couchbase, ya sea alojados en Capella o autogestionados. Proporciona herramientas en categorías que incluyen Salud del Clúster, Esquema de Datos, Clave-Valor, Consultas y Rendimiento — con controles de seguridad mediante modo de solo lectura y desactivación detallada de herramientas. Soporta transportes STDIO y HTTP Transmisible.
El servidor MCP de Couchbase se distribuye como un paquete del Índice de Paquetes de Python (PyPI) y a través de Docker. El soporte empresarial para el Servidor MCP de Couchbase está disponible mediante la licencia de Couchbase AI Data Plane, que también da derecho al uso y soporte empresarial de Couchbase Agent Memory y Couchbase Agent Catalog.
Para la documentación completa, visite mcp-server.couchbase.com.
Características/Herramientas
Herramientas de configuración y salud del clúster
| Nombre de la Herramienta | Descripción |
|---|---|
get_server_configuration_status | Obtiene el estado y la configuración del servidor sin conectarse al clúster — informa el modo de solo lectura, herramientas desactivadas/que requieren confirmación, configuración de OAuth y la configuración de registro resuelta |
test_cluster_connection | Verifica las credenciales del clúster conectándose al clúster |
get_cluster_health_and_services | Obtiene el estado de salud del clúster y la lista de todos los servicios en ejecución |
Herramientas de descubrimiento de esquemas y modelo de datos
| Nombre de la Herramienta | Descripción |
|---|---|
get_buckets_in_cluster | Obtiene una lista de todos los buckets en el clúster |
get_scopes_in_bucket | Obtiene una lista de todos los ámbitos en el bucket especificado |
get_collections_in_scope | Obtiene una lista de todas las colecciones en un ámbito y bucket especificados. Tenga en cuenta que esta herramienta requiere que el clúster tenga el servicio de Consultas. |
get_scopes_and_collections_in_bucket | Obtiene una lista de todos los ámbitos y colecciones en el bucket especificado |
get_schema_for_collection | Obtiene la estructura de una colección |
Herramientas de operaciones KV de documentos
| Nombre de la Herramienta | Descripción |
|---|---|
get_document_by_id | Obtiene un documento por ID de un ámbito y colección especificados |
upsert_document_by_id | Inserta o actualiza (upsert) un documento por ID en un ámbito y colección especificados. Desactivado por defecto cuando CB_MCP_READ_ONLY_MODE=true. |
insert_document_by_id | Inserta un nuevo documento por ID (falla si el documento existe). Desactivado por defecto cuando CB_MCP_READ_ONLY_MODE=true. |
replace_document_by_id | Reemplaza un documento existente por ID (falla si el documento no existe). Desactivado por defecto cuando CB_MCP_READ_ONLY_MODE=true. |
delete_document_by_id | Elimina un documento por ID de un ámbito y colección especificados. Desactivado por defecto cuando CB_MCP_READ_ONLY_MODE=true. |
Herramientas de consultas e indexación
| Nombre de la Herramienta | Descripción |
|---|---|
list_indexes | Lista todos los índices en el clúster con sus definiciones, con filtrado opcional por bucket, ámbito, colección y nombre de índice. Establezca return_raw_index_stats=true para devolver la información del índice sin procesar. |
get_index_advisor_recommendations | Obtiene recomendaciones de índices del Asesor de Índices de Couchbase para una consulta SQL++ dada con el fin de optimizar el rendimiento de la consulta |
run_sql_plus_plus_query | Ejecuta una consulta SQL++ en un ámbito especificado. Las consultas se limitan automáticamente al bucket y ámbito especificados, así que use los nombres de colección directamente (por ejemplo, SELECT * FROM users en lugar de SELECT * FROM bucket.scope.users).CB_MCP_READ_ONLY_MODE está true por defecto, lo que significa que todas las operaciones de escritura (KV y Consultas) están desactivadas. Cuando está activado, las herramientas de escritura KV no se cargan y las consultas SQL++ que modifican datos se bloquean. |
explain_sql_plus_plus_query | Genera y evalúa un plan EXPLAIN para una consulta SQL++. Devuelve metadatos de la consulta, el plan extraído y los hallazgos de la evaluación del plan. |
Herramientas de análisis de rendimiento de consultas
| Nombre de la Herramienta | Descripción |
|---|---|
get_longest_running_queries | Obtiene las consultas de mayor duración por tiempo medio de servicio |
get_most_frequent_queries | Obtiene las consultas ejecutadas con más frecuencia |
get_queries_with_largest_response_sizes | Obtiene las consultas con los mayores tamaños de respuesta |
get_queries_with_large_result_count | Obtiene las consultas con el mayor número de resultados |
get_queries_using_primary_index | Obtiene las consultas que utilizan un índice primario (posible problema de rendimiento) |
get_queries_not_using_covering_index | Obtiene las consultas que no utilizan un índice de cobertura |
get_queries_not_selective | Obtiene las consultas que no son selectivas (los escaneos de índice devuelven muchos más documentos que el resultado final) |
Requisitos previos
- Python 3.10 o superior.
- Un clúster de Couchbase en funcionamiento. La forma más fácil de empezar es usar el nivel gratuito de Capella, que es una versión completamente gestionada del servidor Couchbase. Puede seguir las instrucciones para importar uno de los conjuntos de datos de muestra o importar el suyo propio.
- uv instalado para ejecutar el servidor.
- Un cliente MCP como Claude Desktop instalado para conectar el servidor a Claude. Las instrucciones se proporcionan para Claude Desktop y Cursor. También se podrían usar otros clientes MCP.
Configuración
El servidor MCP se puede ejecutar desde el paquete PyPI precompilado o desde el código fuente usando uv.
Ejecución desde PyPI
Publicamos un paquete PyPI precompilado para el servidor MCP.
Configuración del Servidor usando el Paquete Precompilado para Clientes MCP
Autenticación Básica
{
"mcpServers": {
"couchbase": {
"command": "uvx",
"args": ["couchbase-mcp-server"],
"env": {
"CB_CONNECTION_STRING": "couchbases://connection-string",
"CB_USERNAME": "username",
"CB_PASSWORD": "password"
}
}
}
}
o
mTLS
{
"mcpServers": {
"couchbase": {
"command": "uvx",
"args": ["couchbase-mcp-server"],
"env": {
"CB_CONNECTION_STRING": "couchbases://connection-string",
"CB_CLIENT_CERT_PATH": "/path/to/client-certificate.pem",
"CB_CLIENT_KEY_PATH": "/path/to/client.key"
}
}
}
}
Nota: Si tiene otros servidores MCP en uso en el cliente, puede añadirlo al objeto
mcpServersexistente.
Ejecución desde el Código Fuente
El servidor MCP se puede ejecutar desde el código fuente usando este repositorio.
Clonar el repositorio en su máquina local
git clone https://github.com/couchbase/mcp-server-couchbase.git
Configuración del Servidor usando el Código Fuente para Clientes MCP
Esta es la configuración común para los clientes MCP como Claude Desktop, Cursor, Windsurf Editor.
{
"mcpServers": {
"couchbase": {
"command": "uv",
"args": [
"--directory",
"path/to/cloned/repo/mcp-server-couchbase/",
"run",
"src/mcp_server.py"
],
"env": {
"CB_CONNECTION_STRING": "couchbases://connection-string",
"CB_USERNAME": "username",
"CB_PASSWORD": "password"
}
}
}
}
Nota:
path/to/cloned/repo/mcp-server-couchbase/debe ser la ruta al repositorio clonado en su máquina local. ¡No olvide la barra diagonal al final!
Nota: Si tiene otros servidores MCP en uso en el cliente, puede añadirlo al objeto
mcpServersexistente.
Configuración Adicional para el Servidor MCP
El servidor se puede configurar usando variables de entorno o argumentos de línea de comandos:
| Variable de Entorno | Argumento CLI | Descripción | Valor por Defecto |
|---|---|---|---|
CB_CONNECTION_STRING | --connection-string | Cadena de conexión al clúster de Couchbase | Requerido |
CB_USERNAME | --username | Nombre de usuario con acceso a los buckets requeridos para autenticación básica | Requerido (o se necesita Certificado de Cliente y Clave para mTLS) |
CB_PASSWORD | --password | Contraseña para autenticación básica | Requerido (o se necesita Certificado de Cliente y Clave para mTLS) |
CB_CLIENT_CERT_PATH | --client-cert-path | Ruta al archivo de certificado de cliente para autenticación mTLS | Requerido si se usa mTLS (o se requiere Usuario y Contraseña) |
CB_CLIENT_KEY_PATH | --client-key-path | Ruta al archivo de clave de cliente para autenticación mTLS | Requerido si se usa mTLS (o se requiere Usuario y Contraseña) |
CB_CA_CERT_PATH | --ca-cert-path | Ruta al certificado raíz del servidor para TLS si el servidor está configurado con un certificado autofirmado/no confiable. Esto no será necesario si se conecta a Capella | |
CB_MCP_READ_ONLY_MODE | --read-only-mode | Impide todas las modificaciones de datos (KV y Consultas). Cuando está activado, las herramientas de escritura KV no se cargan. | true |
CB_MCP_TRANSPORT | --transport | Modo de transporte: stdio, http, sse | stdio |
CB_MCP_HOST | --host | Host para los modos de transporte HTTP/SSE | 127.0.0.1 |
CB_MCP_PORT | --port | Puerto para los modos de transporte HTTP/SSE | 8000 |
CB_MCP_DISABLED_TOOLS | --disabled-tools | Herramientas a desactivar (ver Desactivación de Herramientas) | Ninguna |
CB_MCP_CONFIRMATION_REQUIRED_TOOLS | --confirmation-required-tools | Herramientas que requieren confirmación explícita del usuario antes de su ejecución mediante elicitación MCP (ver Herramientas de Elicitación/Confirmación Requerida) | Ninguna |
CB_MCP_LOG_LEVEL | --log-level | Nivel de registro para el servidor MCP: off, debug, info, warning, error (ver Registro) | info |
CB_MCP_LOG_SINKS | --log-sinks | Destinos de registro separados por comas: stderr, file, o ambos (ver Registro) | stderr |
CB_MCP_LOG_FILE | --log-file | Ruta base para archivos de registro por nivel (solo se usa cuando el sumidero file está habilitado) | mcp_server.log |
CB_MCP_LOG_MAX_BYTES | --log-max-bytes | Tamaño máximo en bytes por archivo de registro antes de que rote | 1048576 (1 MB) |
CB_MCP_OAUTH_JWT_JWKS_URI | --oauth-jwks-uri | Endpoint JWKS del proveedor de identidad utilizado para verificar JWTs de portador. Habilita OAuth cuando se establece con el emisor y la audiencia (ver Autorización OAuth 2.1) | Ninguno |
CB_MCP_OAUTH_JWT_ISSUER | --oauth-issuer | Claim iss esperado del JWT. Requerido para habilitar OAuth | Ninguno |
CB_MCP_OAUTH_JWT_AUDIENCE | --oauth-audience | Claim aud esperado del JWT. Requerido para habilitar OAuth | Ninguno |
CB_MCP_OAUTH_JWT_ALGORITHM | --oauth-algorithm | Algoritmo de firma JWT: uno de RS256/384/512, ES256/384/512, PS256/384/512 | RS256 |
CB_MCP_OAUTH_MCP_BASE_URL | --oauth-mcp-base-url | URL base pública de este servidor. Cuando se establece, publica los Metadatos de Recursos Protegidos RFC 9728 para que los clientes conscientes de PRM puedan descubrir el IdP | Ninguno |
Configuración del Modo de Solo Lectura
CB_MCP_READ_ONLY_MODE es el interruptor único que controla las operaciones de escritura:
- Cuando
true(por defecto): Todas las operaciones de escritura (KV y Consultas) están desactivadas. Las herramientas de escritura KV (upsert, insert, replace, delete) no se cargan y no estarán disponibles para el LLM, y las consultas SQL++ que modifican datos o estructura se bloquean. - Cuando
false: Las herramientas de escritura KV se cargan y se permiten las consultas SQL++ de modificación de datos/estructura.
Este es el valor predeterminado seguro recomendado para prevenir modificaciones de datos inadvertidas por parte de los LLMs.
Nota: Para la autenticación, necesita el Nombre de Usuario y la Contraseña o las rutas del Certificado de Cliente y la clave. Opcionalmente, puede especificar la ruta del certificado raíz de CA que se utilizará para validar los certificados del servidor. Si se especifican tanto el Certificado de Cliente y la ruta de la clave como el nombre de usuario y la contraseña, los certificados de cliente se utilizarán para la autenticación.
Desactivación de Herramientas
Puede desactivar herramientas específicas para evitar que se carguen y expongan al cliente MCP. Las herramientas desactivadas no aparecerán en el descubrimiento de herramientas y no podrán ser invocadas por el LLM.
Formatos Soportados
Lista separada por comas:
# Environment variable
CB_MCP_DISABLED_TOOLS="upsert_document_by_id, delete_document_by_id"
# Command line
uvx couchbase-mcp-server --disabled-tools upsert_document_by_id, delete_document_by_id
Ruta de archivo (un nombre de herramienta por línea):
# Environment variable
CB_MCP_DISABLED_TOOLS=disabled_tools.txt
# Command line
uvx couchbase-mcp-server --disabled-tools disabled_tools.txt
Formato de archivo (por ejemplo, disabled_tools.txt):
# Write operations
upsert_document_by_id
delete_document_by_id
# Index advisor
get_index_advisor_recommendations
Las líneas que comienzan con # se tratan como comentarios y se ignoran.
Ejemplos de Configuración del Cliente MCP
Usando lista separada por comas:
{
"mcpServers": {
"couchbase": {
"command": "uvx",
"args": ["couchbase-mcp-server"],
"env": {
"CB_CONNECTION_STRING": "couchbases://connection-string",
"CB_USERNAME": "username",
"CB_PASSWORD": "password",
"CB_MCP_DISABLED_TOOLS": "upsert_document_by_id,delete_document_by_id"
}
}
}
}
Usando ruta de archivo (recomendado para muchas herramientas):
{
"mcpServers": {
"couchbase": {
"command": "uvx",
"args": ["couchbase-mcp-server"],
"env": {
"CB_CONNECTION_STRING": "couchbases://connection-string",
"CB_USERNAME": "username",
"CB_PASSWORD": "password",
"CB_MCP_DISABLED_TOOLS": "/path/to/disabled_tools.txt"
}
}
}
}
Nota de Seguridad Importante
Advertencia: Deshabilitar herramientas por sí solo no garantiza que ciertas operaciones no puedan realizarse. Los permisos RBAC (Control de Acceso Basado en Roles) del usuario de base de datos subyacente son el control de seguridad autoritativo.
Por ejemplo, incluso si deshabilitas
upsert_document_by_idydelete_document_by_id, las modificaciones de datos aún pueden ocurrir a través de la herramientarun_sql_plus_plus_queryusando sentencias DML de SQL++ (INSERT, UPDATE, DELETE, MERGE) a menos que:
CB_MCP_READ_ONLY_MODEesté configurado comotrue(predeterminado), O- El usuario de la base de datos carezca de los permisos RBAC necesarios para la modificación de datos
Mejor práctica: Configura siempre los permisos RBAC apropiados en tus credenciales de usuario de Couchbase como medida de seguridad principal. Usa la deshabilitación de herramientas como una capa adicional para guiar el comportamiento del LLM y reducir la superficie de ataque, no como el único control de seguridad.
Obtención/Confirmación para Llamadas a Herramientas
Puedes requerir confirmación explícita del usuario para herramientas específicas antes de la ejecución (cuando el cliente MCP soporte obtención).
CB_MCP_CONFIRMATION_REQUIRED_TOOLS / --confirmation-required-tools soporta estos formatos:
- Lista separada por comas
- Ruta de archivo (un nombre de herramienta por línea, se soportan comentarios
#)
Ejemplo:
# Environment variable
CB_MCP_CONFIRMATION_REQUIRED_TOOLS="delete_document_by_id,replace_document_by_id"
# Command line
uvx couchbase-mcp-server --confirmation-required-tools delete_document_by_id,replace_document_by_id
Cuando se invoca una herramienta listada:
- Si el cliente soporta obtención, se solicita al usuario que confirme.
- Si el cliente no soporta obtención, la herramienta se ejecuta sin confirmación para compatibilidad con versiones anteriores.
También puedes verificar la versión del servidor usando:
uvx couchbase-mcp-server --version
Registro
El servidor MCP registra en stderr por defecto. El registro se configura con las variables CB_MCP_LOG_* listadas en Configuración Adicional:
CB_MCP_LOG_LEVEL— cuánto se registra:info(el predeterminado) registra eventos del ciclo de vida e invocaciones de herramientas,debugañade detalle interno detallado, yoffdeshabilita todo el registro.CB_MCP_LOG_SINKS— a dónde van los registros:stderr(el predeterminado), archivos rotativos por nivel (file), o ambos. Confile, se escribe un archivo por nivel (por ejemplomcp_server.info.logymcp_server.error.log) en la ruta establecida porCB_MCP_LOG_FILE.
# Enable debug logging to both stderr and rotating per-level files
uvx couchbase-mcp-server --log-level=debug --log-sinks=stderr,file
Para más detalles, consulta la documentación.
Configuración Específica del Cliente
Claude Desktop
Sigue los pasos a continuación para usar el servidor MCP de Couchbase con el cliente MCP de Claude Desktop
-
El servidor MCP ahora se puede añadir a Claude Desktop editando el archivo de configuración. Se pueden encontrar instrucciones más detalladas en la guía de inicio rápido de MCP.
- En Mac, el archivo de configuración se encuentra en
~/Library/Application Support/Claude/claude_desktop_config.json - En Windows, el archivo de configuración se encuentra en
%APPDATA%\Claude\claude_desktop_config.json
Abre el archivo de configuración y añade la configuración a la sección
mcpServers. - En Mac, el archivo de configuración se encuentra en
-
Reinicia Claude Desktop para aplicar los cambios.
-
Ahora puedes usar el servidor en Claude Desktop para ejecutar consultas en el clúster de Couchbase usando lenguaje natural y realizar operaciones CRUD en documentos.
Registros
Los registros de Claude Desktop se pueden encontrar en las siguientes ubicaciones:
- MacOS: ~/Library/Logs/Claude
- Windows: %APPDATA%\Claude\Logs
Los registros se pueden usar para diagnosticar problemas de conexión u otros problemas con la configuración de tu servidor MCP. Para más detalles, consulta la documentación oficial.
Cursor
Sigue los pasos a continuación para usar el servidor MCP de Couchbase con Cursor:
-
Instala Cursor en tu máquina.
-
En Cursor, ve a Cursor > Configuración de Cursor > Herramientas e Integraciones > Herramientas MCP. Además, consulta la documentación sobre configuración del servidor MCP de Cursor.
-
Especifica la misma configuración manualmente, o usa el enlace de un clic Instalar en Cursor. Es posible que necesites añadir la configuración del servidor bajo una clave principal de
mcpServers.Nota: El enlace de instalación usa valores de marcador de posición de los ejemplos de configuración anteriores. Actualiza la cadena de conexión y las credenciales después de la instalación.
-
Guarda la configuración.
-
Verás couchbase como un servidor añadido en la lista de servidores MCP. Actualiza para ver si el servidor está habilitado.
-
Ahora puedes usar el servidor MCP de Couchbase en Cursor para consultar tu clúster de Couchbase usando lenguaje natural y realizar operaciones CRUD en documentos.
Para más detalles sobre la integración de MCP con Cursor, consulta la documentación oficial de MCP de Cursor.
Registros
En el panel inferior de Cursor, haz clic en "Salida" y selecciona "Cursor MCP" del menú desplegable para ver los registros del servidor. Esto puede ayudar a diagnosticar problemas de conexión u otros problemas con la configuración de tu servidor MCP.
Windsurf Editor
Sigue los pasos a continuación para usar el servidor MCP de Couchbase con Windsurf Editor.
-
Instala Windsurf Editor en tu máquina.
-
En Windsurf Editor, navega a Paleta de Comandos > Panel de Configuración MCP de Windsurf o Windsurf - Configuración > Avanzado > Cascade > Servidores del Protocolo de Contexto del Modelo (MCP). Para más detalles sobre la configuración, consulta la documentación oficial.
-
Haz clic en Añadir Servidor y luego en Añadir servidor personalizado. En la configuración que se abre en el editor, añade la configuración del Servidor MCP de Couchbase de arriba.
-
Guarda la configuración.
-
Verás couchbase como un servidor añadido en la lista de Servidores MCP bajo Configuración Avanzada. Actualiza para ver si el servidor está habilitado.
-
Ahora puedes usar el servidor MCP de Couchbase en Windsurf Editor para consultar tu clúster de Couchbase usando lenguaje natural y realizar operaciones CRUD en documentos.
Para más detalles sobre la integración de MCP con Windsurf Editor, consulta la documentación oficial de MCP de Windsurf.
VS Code
Sigue los pasos a continuación para usar el servidor MCP de Couchbase con VS Code.
-
Instala VS Code
-
A continuación se presentan un par de formas de configurar el servidor MCP.
-
Para una configuración de servidor de Espacio de Trabajo
- Crea un nuevo archivo en el espacio de trabajo como .vscode/mcp.json.
- Añade la configuración y guarda el archivo.
-
Para la configuración del servidor Global:
- Ejecuta MCP: Abrir Configuración de Usuario en la Paleta de Comandos (
Ctrl+Shift+PoCmd+Shift+P) - Añade la configuración y guarda el archivo.
- Ejecuta MCP: Abrir Configuración de Usuario en la Paleta de Comandos (
-
Nota: VS Code usa
serverscomo la propiedad JSON de nivel superior en los archivos mcp.json para definir servidores MCP (Protocolo de Contexto del Modelo), mientras que Cursor usamcpServerspara la configuración equivalente. Consulta las configuraciones de cliente de VS Code para cualquier cambio o detalle adicional. A continuación se proporciona un ejemplo de configuración de VS Code.{ "servers": { "couchbase": { "command": "uvx", "args": ["couchbase-mcp-server"], "env": { "CB_CONNECTION_STRING": "couchbases://connection-string", "CB_USERNAME": "username", "CB_PASSWORD": "password" } } } }
-
-
Una vez que guardas el archivo, el servidor se inicia y aparece una pequeña lista de acciones con
Running|Stop|n Tools|More... -
Haz clic en las opciones de la lista de opciones para
Start/Stop/gestionar el servidor. -
Ahora puedes usar el servidor MCP de Couchbase en VS Code para consultar tu clúster de Couchbase usando lenguaje natural y realizar operaciones CRUD en documentos.
Registros:
En la Paleta de Comandos (Ctrl+Shift+P o Cmd+Shift+P),
- ejecuta el comando MCP: Listar Servidores y elige el servidor couchbase
- elige "Mostrar Salida" para ver sus registros en la pestaña de Salida.
IDEs de JetBrains
Sigue los pasos a continuación para usar el servidor MCP de Couchbase con IDEs de JetBrains
- Instala cualquiera de los IDEs de JetBrains
- Instala cualquiera de los plugins de JetBrains - AI Assistant o Junie
- Navega a Configuración > Herramientas > AI Assistant o Junie > Servidor MCP
- Haz clic en "+" para añadir la configuración de MCP de Couchbase y haz clic en Guardar.
- Verás el servidor MCP de Couchbase añadido a la lista de servidores. Una vez que hagas clic en Aplicar, el servidor MCP de Couchbase se inicia y al pasar el cursor sobre el estado, muestra todas las herramientas disponibles.
- Ahora puedes usar el servidor MCP de Couchbase en los IDEs de JetBrains para consultar tu clúster de Couchbase usando lenguaje natural y realizar operaciones CRUD en documentos.
Registros: El archivo de registro se puede explorar en Ayuda > Mostrar Registro en Finder (Explorador) > mcp > couchbase
Modo de Transporte HTTP Transmisible
El Servidor MCP se puede ejecutar en modo de transporte HTTP Transmisible lo que permite que múltiples clientes se conecten a la misma instancia del servidor a través de HTTP. Verifica si tu cliente MCP soporta transporte http transmisible antes de intentar conectarte al servidor MCP en este modo.
Nota: La autorización OAuth 2.1 está soportada en este transporte. Consulta Autorización OAuth 2.1. Sin OAuth configurado, el endpoint HTTP no está autenticado.
Uso
Por defecto, el servidor MCP se ejecutará en el puerto 8000 pero esto se puede configurar usando la variable de entorno --port o CB_MCP_PORT.
uvx couchbase-mcp-server \
--connection-string='<couchbase_connection_string>' \
--username='<database_username>' \
--password='<database_password>' \
--read-only-mode=true \
--transport=http
El servidor estará disponible en http://localhost:8000/mcp. Esto se puede usar en clientes MCP que soporten el modo de transporte http transmisible como Cursor.
Configuración del Cliente MCP
{
"mcpServers": {
"couchbase-http": {
"url": "http://localhost:8000/mcp"
}
}
}
Modo de Transporte SSE
Existe una opción para ejecutar el servidor MCP en modo de transporte Eventos Enviados por el Servidor (SSE).
Nota: El modo SSE ha sido obsoleto por MCP. Tenemos soporte para HTTP Transmisible.
SSE: Uso
Por defecto, el servidor MCP se ejecutará en el puerto 8000 pero esto se puede configurar usando la variable de entorno --port o CB_MCP_PORT.
uvx couchbase-mcp-server \
--connection-string='<couchbase_connection_string>' \
--username='<database_username>' \
--password='<database_password>' \
--read-only-mode=true \
--transport=sse
El servidor estará disponible en http://localhost:8000/sse. Esto se puede usar en clientes MCP que soporten el modo de transporte SSE como Cursor.
SSE: Configuración del Cliente MCP
{
"mcpServers": {
"couchbase-sse": {
"url": "http://localhost:8000/sse"
}
}
}
Autorización OAuth 2.1
Cuando se ejecuta con --transport=http, el servidor MCP puede actuar como un servidor de recursos OAuth 2.1: valida los JWT de portador entrantes contra el JWKS de tu proveedor de identidad. Es agnóstico al proveedor (cualquier proveedor OAuth 2.1 / OIDC que publique un JWKS — Auth0, Okta, Keycloak, AWS Cognito, Microsoft Entra, etc.) y no emite tokens ni gestiona usuarios. La configuración de OAuth se ignora en stdio.
OAuth se configura con las variables CB_MCP_OAUTH_* listadas en Configuración Adicional:
- OAuth se activa solo cuando las tres
CB_MCP_OAUTH_JWT_JWKS_URI,CB_MCP_OAUTH_JWT_ISSUERyCB_MCP_OAUTH_JWT_AUDIENCEestán configuradas; configurar solo algunas de ellas falla al inicio. - Configurar
CB_MCP_OAUTH_MCP_BASE_URLadicionalmente publica Metadatos de Recurso Protegido RFC 9728 para que los clientes conscientes de PRM puedan descubrir el servidor de autorización. - El acceso está controlado por dos ámbitos leídos del claim
scope/scpdel token:couchbase-mcp:read(herramientas de lectura, incluyendo SQL++) ycouchbase-mcp:write(herramientas de mutación KV). El acceso completo requiere ambos.
uvx couchbase-mcp-server \
--connection-string='<couchbase_connection_string>' \
--username='<database_username>' \
--password='<database_password>' \
--transport=http \
--oauth-jwks-uri='https://auth.example.com/.well-known/jwks.json' \
--oauth-issuer='https://auth.example.com/' \
--oauth-audience='couchbase-mcp-server' \
--oauth-mcp-base-url='<public_base_url_of_this_server>'
Para detalles completos, consulta la documentación.
Imagen Docker
El servidor MCP también se puede construir y ejecutar como un contenedor Docker. Las imágenes preconstruidas se pueden encontrar en DockerHub o se pueden obtener mediante docker pull docker.io/couchbase/mcp-server:latest.
Alternativamente, somos parte del Catálogo MCP de Docker.
Construyendo la Imagen
docker build -t mcp/couchbase-src .
Construyendo con Argumentos
Si deseas construir con los argumentos de construcción para el hash del commit y la hora de construcción, puedes construir usando:docker build --build-arg GIT_COMMIT_HASH=$(git rev-parse HEAD) \
--build-arg BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ') \
-t mcp/couchbase-src .
Alternativamente, usa el script de construcción proporcionado:
# Build with default image name (mcp/couchbase-src)
./build.sh
# Build with custom image name
./build.sh my-custom/image-name
Este script automáticamente:
- Acepta un parámetro opcional de nombre de imagen (por defecto
mcp/couchbase-src) - Genera el hash del commit de git y la marca de tiempo de compilación
- Crea múltiples etiquetas útiles (
latest,<short-commit>) - Muestra información de compilación y resultados
- Utiliza los mismos argumentos que las compilaciones de CI/CD
Verificar etiquetas de imagen:
# View git commit hash in image
docker inspect --format='{{index .Config.Labels "org.opencontainers.image.revision"}}' mcp/couchbase-src:latest
# View all metadata labels
docker inspect --format='{{json .Config.Labels}}' mcp/couchbase-src:latest
Ejecución
El servidor MCP puede ejecutarse utilizando variables de entorno para configurar los ajustes de Couchbase. Las variables de entorno son las mismas que se describen en la sección de Configuración Adicional.
Contenedor Docker Independiente
docker run --rm -i \
-e CB_CONNECTION_STRING='<couchbase_connection_string>' \
-e CB_USERNAME='<database_user>' \
-e CB_PASSWORD='<database_password>' \
-e CB_MCP_TRANSPORT='<http|sse|stdio>' \
-e CB_MCP_READ_ONLY_MODE='<true|false>' \
-e CB_MCP_CONFIRMATION_REQUIRED_TOOLS='delete_document_by_id' \
-e CB_MCP_PORT=9001 \
-e CB_MCP_HOST=0.0.0.0 \
-p 9001:9001 \
mcp/couchbase-src
Las variables de entorno CB_MCP_PORT y CB_MCP_HOST solo son aplicables en el caso de modos de transporte HTTP como http y sse.
Docker: Configuración del Cliente MCP
La imagen Docker puede utilizarse en modo de transporte stdio con la siguiente configuración.
{
"mcpServers": {
"couchbase-mcp-docker": {
"command": "docker",
"args": [
"run",
"--rm",
"-i",
"-e",
"CB_CONNECTION_STRING=<couchbase_connection_string>",
"-e",
"CB_USERNAME=<database_user>",
"-e",
"CB_PASSWORD=<database_password>",
"mcp/couchbase-src"
]
}
}
}
Notas
- El valor de
couchbase_connection_stringdepende de si el servidor Couchbase se está ejecutando en la misma máquina host, en otro contenedor Docker o en un host remoto. Si su servidor Couchbase se ejecuta en su máquina host, su cadena de conexión probablemente tendría la formacouchbase://host.docker.internal. Para más detalles, consulte la documentación de docker. - Puede especificar la red del contenedor usando la opción
--network=<your_network>. La red que elija depende de su entorno; la predeterminada esbridge. Para más detalles, consulte controladores de red en docker.
Riesgos Asociados con los LLMs
- El uso de modelos de lenguaje grandes y tecnología similar implica riesgos, incluyendo la posibilidad de resultados inexactos o perjudiciales.
- Couchbase no revisa ni evalúa la calidad o precisión de dichos resultados, y estos pueden no reflejar las opiniones de Couchbase.
- Usted es el único responsable de determinar si utiliza modelos de lenguaje grandes y tecnología relacionada, y de cumplir con los términos de licencia, condiciones de uso y las políticas de su organización que rigen su uso.
Consejos para Solución de Problemas
- Asegúrese de que la ruta a su repositorio del servidor MCP sea correcta en la configuración si lo ejecuta desde el código fuente.
- Verifique que su cadena de conexión de Couchbase, nombre de usuario de la base de datos, contraseña o la ruta a los certificados sean correctos.
- Si utiliza Couchbase Capella, asegúrese de que el clúster sea accesible desde la máquina donde se ejecuta el servidor MCP.
- Compruebe que el usuario de la base de datos tenga los permisos adecuados para acceder al menos a un bucket.
- Confirme que el gestor de paquetes
uvesté correctamente instalado y accesible. Puede que necesite proporcionar la ruta absoluta auv/uvxen el campocommandde la configuración. - Revise los registros en busca de errores o advertencias que puedan indicar problemas con el servidor MCP. La ubicación de los registros depende de su cliente MCP.
- Si observa problemas al ejecutar su servidor MCP desde el código fuente después de actualizar su repositorio local del servidor MCP, intente ejecutar
uv syncpara actualizar las dependencias.
Pruebas de Integración
Proporcionamos pruebas de integración MCP de alto nivel para verificar que el servidor expone las herramientas esperadas y que pueden invocarse contra un clúster Couchbase de demostración.
- Exportar credenciales del clúster de demostración:
CB_CONNECTION_STRINGCB_USERNAMECB_PASSWORD- Opcional:
CB_MCP_TEST_BUCKET(un bucket para sondear durante las pruebas)
- Ejecutar las pruebas:
uv run pytest tests/ -v
👩💻 Contribuciones
¡Agradecemos las contribuciones de la comunidad! Ya sea que desee corregir errores, añadir funcionalidades o mejorar la documentación, su ayuda es bienvenida.
Si necesita ayuda, ha encontrado un error o desea contribuir con mejoras, el mejor lugar para hacerlo es aquí mismo — abriendo un issue en GitHub.
Para Desarrolladores
Si está interesado en contribuir con código o configurar un entorno de desarrollo:
📖 Consulte CONTRIBUTING.md para obtener instrucciones completas de configuración para desarrolladores, que incluyen:
- Configuración del entorno de desarrollo con
uv - Linting y formateo de código con Ruff
- Instalación de hooks de pre-commit
- Descripción general de la estructura del proyecto
- Flujo de trabajo y prácticas de desarrollo
Inicio Rápido para Contribuidores
# Clone and setup
git clone https://github.com/couchbase/mcp-server-couchbase.git
cd mcp-server-couchbase
# Install with development dependencies
uv sync --extra dev
# Install pre-commit hooks
uv run pre-commit install
# Run linting
./scripts/lint.sh
📢 Política de Soporte
¡Apreciamos sinceramente su interés en este proyecto! Este proyecto es mantenido por la comunidad de Couchbase, lo que significa que no cuenta con soporte oficial de nuestro equipo de soporte. Sin embargo, nuestros ingenieros supervisan y mantienen activamente este repositorio e intentarán resolver los problemas con el mayor esfuerzo posible.
Nuestro portal de soporte no puede asistir con solicitudes relacionadas con este proyecto, por lo que le pedimos amablemente que todas las consultas se mantengan dentro de GitHub.
Su colaboración nos ayuda a todos a avanzar juntos — ¡gracias!