qmcp
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., "@qmcpsearch for code related to OAuth authentication"
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.
qmcp - QDrant MCP Server for OpenCode
Semantic search server for code and documentation using Qdrant vector database.
Language: English | Русский
Features
Semantic Search: Find code and documentation using natural language queries
Multi-language Support: Python, Go, JavaScript, TypeScript, Java, C#, Markdown
Live Updates: File watcher for automatic reindexing
Incremental Indexing: Only index changed files
Gitignore Support: Respects
.gitignore- excludesnode_modules,__pycache__,.venv, build artifacts, etc.Cleanup: Remove stale vectors for deleted/changed files
Diagnostics: Introspection tools to understand what's indexed
OpenCode Skill: Natural language interface for Qdrant management
Installation
Via PyPI (Recommended)
pip install qmcp-qdrantVia uv
uv tool install qmcp-qdrantFrom Source
git clone https://github.com/BigKAA/qmcp.git
cd qmcp
make installUpdating
Via uv (Recommended)
uv tool upgrade qmcp-qdrantVia pip
pip install --upgrade qmcp-qdrantQuick Start
1. Ensure Qdrant is running
For Kubernetes deployment, see Qdrant on Kubernetes.
2. Add MCP Server to OpenCode
opencode mcp add qmcp-qdrant qmcp-qdrant⚠️ Note: Environment variables must be set in
~/.config/opencode/opencode.jsonconfig file.
Configuration
Environment Variable | Default | Description |
|
| Qdrant server URL |
| (none) | Qdrant API key (optional) |
|
| Embedding model |
| (system temp) | Custom directory for model cache |
|
| Baseline paths to watch automatically on server startup |
|
| Batch size for indexing |
|
| Debounce delay |
|
| Logging level |
|
| Log format ( |
💡 Model Cache: Set
EMBEDDING_CACHE_DIRto persist models across restarts. First launch downloads the model (~13MB), subsequent launches use cached version.
💡 WATCH_PATHS examples:
Single path:
WATCH_PATHS=/home/user/projectMultiple paths:
WATCH_PATHS=/home/user/project,/home/user/docsJSON array:
WATCH_PATHS=["/home/user/project", "/home/user/docs"]
3. That's It!
OpenCode will automatically discover and use the semantic search tools.
Manual Configuration (Alternative)
If opencode mcp add doesn't work, edit ~/.config/opencode/opencode.json directly:
{
"mcp": {
"qmcp-qdrant": {
"type": "local",
"command": ["qmcp-qdrant"],
"environment": {
"QDRANT_URL": "http://192.168.218.190:6333",
"WATCH_PATHS": "/home/user/shared-docs,/home/user/shared-snippets"
}
}
}
}For Python module:
{
"mcp": {
"qmcp-qdrant": {
"type": "local",
"command": ["python", "-m", "qmcp.server"],
"environment": {
"QDRANT_URL": "http://192.168.218.190:6333",
"WATCH_PATHS": "/home/user/shared-docs,/home/user/shared-snippets"
}
}
}
}Indexing Notes
⚠️ Important: Full indexing and reindexing of large projects can take a significant amount of time (minutes to hours depending on project size).
For large codebases, prefer:
Incremental reindex (
mode="incremental") - only updates changed files based on content hashesFile watcher - enables automatic live updates when files change
Automatic Indexing Strategy
qmcp supports automatic indexing on two levels:
Server startup level — on MCP startup, the server automatically tries to start a watcher for
WATCH_PATHS.Workspace session level — because one global MCP server can be shared across multiple repositories, agents should check the watcher state for the current workspace and call
qdrant_watch_ensure(paths=[workspace_root])when the workspace path is missing.
Recommended OpenCode flow for every new workspace:
status = qdrant_get_status()
# If watcher is not active or the current repo is not covered,
# safely extend the watcher without dropping other projects.
qdrant_watch_ensure(paths=["/absolute/path/to/current/workspace"])qdrant_watch_ensure merges the current workspace with already watched paths and WATCH_PATHS, making it safe for a single global MCP shared by multiple projects.
MCP Tools
Search & Indexing
Tool | Description |
| Semantic search in code/docs |
| Index a directory |
| Reindex (full or incremental) |
💡 Tip: Use
qdrant_searchwith filters for precise results:
chunk_type— filter by code type (function_def, class_def, etc.)
symbol_name— find exact symbol by name
language— filter by programming languageSee docs/STRUCTURED_METADATA.md for detailed examples.
Collection Management
Tool | Description |
| List all collections |
| Get collection info |
| Delete collection |
Diagnostics & Introspection
Tool | Description |
| Full collection diagnostics - vectors, files, types, issues |
| Paginated list of indexed files with metadata |
| Compare Qdrant state with filesystem (orphans, missing, modified) |
Maintenance
Tool | Description |
| Clean stale vectors (dry-run supported) |
| Start file watcher |
| Ensure workspace path is watched without dropping other projects |
| Stop file watcher |
| Server status |
Diagnostic Tools Usage Examples
# Diagnose a collection - see what's indexed, file types, issues
qdrant_diagnose_collection(collection="myproject")
# List indexed files with pagination
qdrant_list_indexed_files(collection="myproject", limit=50, offset=0)
# Filter by file type
qdrant_list_indexed_files(collection="myproject", file_type=".py")
# Compare Qdrant state with filesystem
qdrant_diff_collection(collection="myproject", repo_path="/path/to/repo")OpenCode Skill
The project includes an OpenCode skill for natural language management of Qdrant.
Installation
# Copy skill to OpenCode skills directory
cp -r skills/qmcp-manager ~/.config/opencode/skills/Usage
Once installed, OpenCode will automatically activate the skill when you ask questions like:
Query | What Happens |
| Diagnoses collection and shows stats |
| Lists all collections with vector counts |
| Finds and previews deletion of orphaned vectors |
| Full diagnostics with issues and file list |
| Shows orphans, missing, and modified files |
| Lists files on disk but not indexed |
| Compares hashes to detect changes |
Workflows Provided by Skill
Quick Status - Check collection state with
qdrant_list_collectionsFull Diagnostics - Detailed analysis with
qdrant_diagnose_collectionDiff - Compare Qdrant with filesystem using
qdrant_diff_collectionSafe Cleanup - Preview with dry-run, then confirm deletion
Smart Reindex - Incremental updates based on file hashes
Skill Location
skills/qmcp-manager/SKILL.mdManage MCP Servers
opencode mcp list # List all MCP servers
opencode mcp debug qmcp-qdrant # Debug connection issues
opencode mcp logout qmcp-qdrant # Remove MCP serverDevelopment
make install # Install dependencies
make test # Run tests
make lint # Lint code
make format # Format code
make mcp-dev # Run with MCP inspectorTroubleshooting
If you encounter issues, see the Troubleshooting Guide for:
Embedding Model Issues —
indexed_vectors_count: 0diagnosis and fixConnection Problems — Qdrant connection troubleshooting
Search Returns No Results — Empty search results debugging
License
Apache 2.0
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/BigKAA/qmcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server