mcp-context-cache
Allows configuring the mcp-context-cache server in JetBrains IDEs (IntelliJ, WebStorm, PyCharm) to provide efficient context caching for AI agents, enabling single-tool access to project files.
Allows configuring the mcp-context-cache server in PyCharm to provide efficient context caching for AI agents, enabling single-tool access to project files.
Allows configuring the mcp-context-cache server in WebStorm to provide efficient context caching for AI agents, enabling single-tool access to project files.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-context-cacheload project context using contextcache.json"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-context-cache
Caché de contexto para agentes de IA. Carga, almacena y entrega el contexto de archivos del proyecto de forma eficiente usando el Protocolo de Contexto de Modelos (MCP).
¿Por qué usarlo?
Sin este servidor | Con este servidor |
El agente llama a | Una sola llamada devuelve todo el proyecto |
30 archivos = 30 tool calls | 30 archivos = 1 tool call |
Características
Caché LRU — Los archivos se hashean con SHA-256 y se almacenan en memoria. Los archivos sin cambios nunca se vuelven a leer del disco.
Pipeline de seguridad — 8 pasos de validación bloquean archivos sensibles (
.env,*.pem, credenciales, binarios, etc.).3 herramientas MCP — Carga de contexto flexible: por lista de archivos, directorio o archivo de configuración.
Truncado inteligente — Respeta límites de tamaño configurables y reporta los archivos omitidos.
Orden alfabético — Salida determinista para respuestas estables del agente de IA.
Instalación
Instalación global (recomendada)
npm install -g mcp-context-cacheCon pnpm:
pnpm add -g mcp-context-cacheVerificar la instalación:
mcp-context-cache --versionSin instalar
npx mcp-context-cache --initGuía de configuración
Paso 1 — Registra el servidor MCP en tu IDE
VS Code
Opción A — Global (todos los workspaces):
Edita ~/.config/Code/User/mcp.json en macOS/Linux o %APPDATA%\Code\User\mcp.json en Windows:
{
"servers": {
"mcp-context-cache": {
"type": "stdio",
"command": "mcp-context-cache"
}
}
}Opción B — Por workspace:
Crea .vscode/mcp.json en la raíz del proyecto:
{
"servers": {
"mcp-context-cache": {
"type": "stdio",
"command": "mcp-context-cache"
}
}
}JetBrains (IntelliJ, WebStorm, PyCharm, etc.)
Crea .mcp.json en la raíz del proyecto:
{
"mcpServers": {
"mcp-context-cache": {
"command": "mcp-context-cache"
}
}
}JetBrains AI Assistant detecta
.mcp.jsonautomáticamente desde la versión 2024.3.
Paso 2 — Instrucciones al agente para preferir las herramientas MCP
Los agentes de IA usan sus herramientas nativas por defecto. Debes indicarles explícitamente que prefieran las del servidor MCP.
VS Code — Instrucciones globales
Crea el archivo ~/.config/Code/User/prompts/mcp-context-cache.instructions.md:
---
applyTo: "**"
---
# Carga de contexto — mcp-context-cache
## HERRAMIENTAS PROHIBIDAS
NUNCA uses estas herramientas para leer archivos del proyecto:
- `read_file`
- `list_dir`
- `file_search`
- `semantic_search`
- `grep_search`
Solo se permite usarlas si TODAS las herramientas MCP fallan con error.
## PROCEDIMIENTO OBLIGATORIO
Antes de cualquier otra llamada al inicio de una tarea:
1. Verifica si el workspace contiene un archivo `contextcache.json`.
2. Si existe → llama a `get_context_from_config` con `{ "projectRoot": "<ruta-absoluta>" }`.
3. Si no existe y necesitas un directorio → llama a `get_directory_context`.
4. Para archivos específicos → llama a `get_project_context` con un array `paths`.
5. Solo usa `read_file` si las tres herramientas MCP devuelven error.
## Referencia de herramientas
- `get_context_from_config` → `{ "projectRoot": "<ruta-absoluta>" }`
- `get_project_context` → `{ "paths": ["rel/ruta.ts", ...], "projectRoot": "<ruta-absoluta>" }`
- `get_directory_context` → `{ "rootPath": "<ruta-absoluta-al-directorio>" }`El frontmatter
applyTo: "**"le indica a VS Code Copilot que inyecte este archivo en cada conversación.
VS Code — Por proyecto
Crea .github/copilot-instructions.md en la raíz del proyecto:
## PROHIBIDO — no uses estas herramientas para leer archivos
NUNCA llames a `read_file`, `list_dir`, `file_search`, `semantic_search` o `grep_search`.
Solo recurre a ellas si todas las herramientas MCP devuelven error.
## PRIMER PASO OBLIGATORIO
Este proyecto tiene un `contextcache.json`. Llama a `get_context_from_config` antes de cualquier otra herramienta:
{ "projectRoot": "<ruta-absoluta-a-este-repo>" }JetBrains — Prompt de sistema global (AI Assistant)
Ve a Settings → Tools → AI Assistant → System prompt y agrega:
Al trabajar en cualquier proyecto que tenga un archivo contextcache.json, llama a la herramienta MCP
get_context_from_config con la ruta raíz del proyecto antes de leer archivos individuales.
Prefiere get_directory_context sobre leer archivos uno por uno, y get_project_context
sobre múltiples llamadas a read_file.Paso 3 — Inicializa tu proyecto
Ejecuta en la raíz del proyecto para generar un contextcache.json:
npx @jdug-jadodev/mcp-context-cache --initO créalo manualmente:
{
"modules": [
{
"name": "src",
"path": "src",
"includeInstructions": true,
"excludePatterns": ["**/*.test.ts", "**/*.spec.ts", "**/__mocks__/**"]
}
],
"globalInstructions": ".github/copilot-instructions.md",
"maxTotalSizeKb": 2048,
"cache": {
"maxEntries": 5000,
"maxEntrySizeKb": 1024
},
"security": {
"allowedPaths": ["./"],
"deniedPaths": ["./node_modules", "./dist", "./secrets", "./.git"],
"deniedFiles": [".env", "credentials.json", "*.pem"],
"maxFileSizeKb": 500,
"allowedExtensions": [".ts", ".tsx", ".js", ".jsx", ".json", ".md", ".yaml", ".yml"]
}
}Referencia de campos
Campo | Descripción |
| Lista de directorios a empaquetar |
| Ruta relativa a la raíz del proyecto |
| Si es |
| Patrones glob a omitir |
| Ruta al Markdown incluido al inicio del bundle cuando |
| Tamaño máximo total del bundle en KB |
| Número máximo de archivos en la caché LRU |
| Tamaño máximo de archivo individual en caché |
| Rutas desde las que el servidor puede leer |
| Rutas siempre bloqueadas |
| Patrones de nombres de archivo siempre bloqueados |
| Tamaño máximo de archivo a servir |
| Lista blanca de extensiones de archivo |
Herramientas MCP
get_context_from_config
Carga el contexto completo del proyecto definido en contextcache.json. Úsala siempre primero.
{ "projectRoot": "/ruta/absoluta/al/proyecto" }Parámetro | Tipo | Requerido | Descripción |
| string | sí | Directorio que contiene |
| string | no | Ruta explícita a |
get_directory_context
Carga recursivamente todos los archivos de un directorio.
{ "rootPath": "/ruta/absoluta/al/directorio", "excludePatterns": ["*.test.ts"] }Parámetro | Tipo | Requerido | Descripción |
| string | sí | Directorio a escanear |
| string | no | Ruta a |
| string[] | no | Patrones glob adicionales a excluir |
get_project_context
Carga una lista específica de archivos por ruta.
{ "paths": ["src/auth/login.ts", "src/types.ts"], "projectRoot": "/ruta/absoluta" }Parámetro | Tipo | Requerido | Descripción |
| string[] | sí | Rutas de archivos a cargar |
| string | no | Raíz para resolver rutas relativas |
| string | no | Ruta a |
Formato de salida
Cada archivo en el bundle se envuelve con marcadores BUNDLE:
BUNDLE_START: <sha256-fingerprint>
ruta/al/archivo.ts
<contenido completo del archivo>
BUNDLE_END: ruta/al/archivo.tsLos archivos siempre se ordenan alfabéticamente para una salida determinista.
Manejo de BUNDLE_TRUNCATED
Cuando el tamaño total supera maxTotalSizeKb, la respuesta incluye:
BUNDLE_TRUNCATED: límite de tamaño excedido.
Límite configurado: 2048 KB
Tamaño total: 3100 KB
Archivos omitidos:
src/modulo-grande/archivo-a.ts
src/modulo-grande/archivo-b.tsLlama a get_project_context con las rutas omitidas para recuperarlos en una llamada de seguimiento.
Seguridad
Los siguientes archivos están siempre bloqueados, independientemente del contextcache.json:
.env,.env.*,credentials.json,*.pem,id_rsa,id_ed25519*.key,private.key,secret*,secrets.json,token*service-account.json,.npmrc,.pypircTodos los binarios:
.exe,.dll,.png,.zip,.wasm, etc.
Las rutas fuera de allowedPaths son rechazadas. El servidor nunca sigue symlinks fuera del árbol permitido.
Desarrollo
pnpm install
pnpm build # Compila TypeScript → dist/
pnpm dev # Ejecuta con tsx (sin paso de build)
pnpm test # Suite de tests con VitestLicencia
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/jdug-jadodev/MCP-CACHING'
If you have feedback or need assistance with the MCP directory API, please join our Discord server