Mock Interview RAG Server
Fetches your public GitHub repositories, indexes them into a vector database, and exposes semantic code search tools for technical mock interviews grounded in your actual code.
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., "@Mock Interview RAG ServerSearch my codebase for how I handle API errors."
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.
Mock Interview RAG Server
A Dockerized MCP server that fetches your GitHub repositories, indexes them into a local vector database, and exposes semantic code search tools to an LLM client (Claude Desktop or Cursor) so it can conduct tailored technical mock interviews grounded in your actual code.
MCP (Model Context Protocol) is a protocol that lets LLM clients call typed tools declared by an external server. The LLM decides when to call a tool, passes typed arguments, and receives structured results — all over stdio. This server exposes two tools (search_codebase and list_available_repositories) that give the LLM real-time access to your source code during an interview session.
Architecture
The system runs across three phases: repository ingestion on your host machine, vector embedding inside the container, and MCP tool exposure over stdio.
flowchart TD
subgraph host [Host Machine]
cloner["cloner.py\n(fetch + git clone)"]
GitHub["GitHub\n(repos.json + source)"]
repos["repositories/\n(cloned source code)"]
GitHub -->|"fetch repos.json"| cloner
cloner -->|"git clone"| repos
end
subgraph container [Docker Container]
indexer["indexer.py\n(RAG pipeline)"]
vectordb["vector_db/\n(ChromaDB)"]
server["server.py\n(FastMCP)"]
indexer -->|"upsert embeddings"| vectordb
server -->|"query"| vectordb
end
repos -->|"bind mount"| indexer
vectordb -->|"bind mount"| host
subgraph client [MCP Client]
LLM["Claude Desktop\nor Cursor"]
end
LLM <-->|"stdio"| serverPhase | Component | Responsibility |
1. Ingestion |
| Fetches |
2. Embedding |
| Walks the mounted |
3. Protocol |
| Exposes |
Related MCP server: mcp-context
Prerequisites
Python 3.11+ — for the host-side
make clone-reposscriptDocker + Docker Compose — to build and run the container
Git — used by the cloner script
Make — to run the convenience targets
Project Structure
Learn_MCP_server/
├── repositories/ # Cloned target source code (gitignored, populated by make clone-repos)
├── vector_db/ # Persistent ChromaDB storage (gitignored, populated on container start)
├── src/
│ ├── __init__.py
│ ├── repo.py # Repo dataclass
│ ├── cloner.py # Fetches repos.json from GitHub and git-clones each repo
│ ├── server.py # MCP server — exposes tools to the LLM client
│ └── indexer.py # RAG pipeline — embeds source files into ChromaDB
├── Dockerfile
├── docker-compose.yml
├── Makefile
└── requirements.txtQuick Start
# 1. Clone this repository
git clone https://github.com/TheTangentLine/Learn_MCP_server
cd Learn_MCP_server
# 2. Clone target repos, build the image, and start the server (detached)
make run
# 3. Add the server to your MCP client config (see below)make run chains clone-repos → build → docker compose up -d in one step.
Other useful targets:
Target | Command | Description |
Clone repos only |
| Fetch |
Build image only |
| Build the Docker image without starting |
Tail logs |
| Follow live container output |
Stop & clean up |
| Stop the container and remove it |
Connecting to an MCP Client
Once the container is running, register it in your MCP client's configuration file.
Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"mock-interview": {
"command": "docker",
"args": [
"compose",
"-f",
"/path/to/Learn_MCP_server/docker-compose.yml",
"run",
"--rm",
"mcp-server"
]
}
}
}Cursor (.cursor/mcp.json in your project or ~/.cursor/mcp.json globally):
{
"mcpServers": {
"mock-interview": {
"command": "docker",
"args": [
"compose",
"-f",
"/path/to/Learn_MCP_server/docker-compose.yml",
"run",
"--rm",
"mcp-server"
]
}
}
}Restart your client after saving the config to load the new server.
For implementation details — component code, concept explanations, and troubleshooting — see docs/docs.md.
This server cannot be installed
Maintenance
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/TheTangentLine/Learn_MCP_server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server