loading…
Search for a command to run...
loading…
MCP server for semantic and hybrid search over RHEL documentation using docs2db RAG, with cross-encoder reranking and support for multiple MCP clients.
MCP server for semantic and hybrid search over RHEL documentation using docs2db RAG, with cross-encoder reranking and support for multiple MCP clients.
MCP server for docs2db-api RAG queries. Provides semantic and hybrid search tools for RHEL documentation. Compatible with llama-stack, Goose, Claude Desktop, and other MCP clients.
Install uv:
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Or with brew
brew install uv
uv add docs2db-mcp-server
git clone https://github.com/rhel-lightspeed/docs2db-mcp-server.git
cd docs2db-mcp-server
uv sync
uv pip install -e .
# Start the MCP server (uses localhost defaults)
uv run python -m docs2db_mcp
Default configuration connects to postgresql://postgres:postgres@localhost:5432/ragdb
Server will start on http://localhost:8002/sse
Add to your run.yaml:
tool_runtime:
- provider_id: model-context-protocol
provider_type: remote::model-context-protocol
registered_resources:
tool_groups:
- toolgroup_id: mcp::docs2db-rag
provider_id: model-context-protocol
mcp_endpoint:
uri: http://localhost:8002/sse
Add to ~/.config/goose/config.yaml:
extensions:
docs2db-rag:
enabled: true
type: stdio
name: docs2db-rag
cmd: uv
args:
- run
- python
- -m
- docs2db_mcp
envs:
DOCS2DB_MCP_TRANSPORT: stdio
Add to claude_desktop_config.json:
{
"mcpServers": {
"docs2db-rag": {
"command": "uv",
"args": ["run", "python", "-m", "docs2db_mcp"]
}
}
}
All configuration via environment variables with DOCS2DB_MCP_ prefix.
Note: For stdio transport, DOCS2DB_LOG_LEVEL is automatically set to CRITICAL to minimize startup logs. Set manually if needed.
| Variable | Default | Description |
|---|---|---|
DOCS2DB_MCP_TRANSPORT |
sse |
Transport type (sse/stdio) |
DOCS2DB_MCP_HOST |
0.0.0.0 |
Bind address |
DOCS2DB_MCP_PORT |
8002 |
Port number |
DOCS2DB_MCP_LOG_LEVEL |
INFO |
Logging level |
DOCS2DB_MCP_SHOW_BANNER |
true |
Show FastMCP banner (auto-suppressed for stdio) |
| Variable | Default | Description |
|---|---|---|
DOCS2DB_MCP_DB_HOST |
localhost |
PostgreSQL host |
DOCS2DB_MCP_DB_PORT |
5432 |
PostgreSQL port |
DOCS2DB_MCP_DB_DATABASE |
ragdb |
Database name |
DOCS2DB_MCP_DB_USER |
postgres |
Database user |
DOCS2DB_MCP_DB_PASSWORD |
postgres |
Database password |
| Variable | Default | Description |
|---|---|---|
DOCS2DB_MCP_RAG_SIMILARITY_THRESHOLD |
0.7 |
Minimum similarity score |
DOCS2DB_MCP_RAG_MAX_CHUNKS |
5 |
Maximum chunks to return |
DOCS2DB_MCP_RAG_ENABLE_RERANKING |
true |
Enable cross-encoder reranking |
Search RHEL documentation using hybrid search (vector + BM25).
Parameters:
query (string, required): Search querymax_chunks (integer, optional): Maximum chunks to return (default: 5)similarity_threshold (float, optional): Minimum similarity score (default: 0.7)enable_reranking (boolean, optional): Enable cross-encoder reranking (default: true)Returns:
{
"chunks": [
{
"text": "Chunk content...",
"contextual_text": "LLM-generated context...",
"similarity": 0.85,
"source": "path/to/source/file.html",
"metadata": {...}
}
],
"query_used": "original query"
}
podman build -t docs2db-mcp-server .
podman run -d \
--name docs2db-mcp \
-p 8002:8002 \
-e DOCS2DB_MCP_DB_HOST=postgres \
-e DOCS2DB_MCP_DB_PASSWORD=mysecret \
docs2db-mcp-server
services:
postgres:
image: pgvector/pgvector:pg17
environment:
POSTGRES_PASSWORD: postgres
volumes:
- ragdb:/var/lib/postgresql/data
- ./ragdb_dump.sql:/docker-entrypoint-initdb.d/init.sql
docs2db-mcp:
image: docs2db-mcp-server
ports:
- "8002:8002"
environment:
DOCS2DB_MCP_DB_HOST: postgres
DOCS2DB_MCP_DB_PASSWORD: postgres
depends_on:
- postgres
# Clone repo
git clone https://github.com/rhel-lightspeed/docs2db-mcp-server.git
cd docs2db-mcp-server
# Install dependencies
uv sync
uv pip install -e ".[dev]"
# Run tests
uv run pytest
# Run linters
uv run ruff check .
uv run mypy src/
┌─────────────────────────────────────┐
│ MCP Client │
│ (llama-stack, Goose, Claude, etc.) │
└──────────────┬──────────────────────┘
│ MCP Protocol (SSE/stdio)
↓
┌─────────────────────────────────────┐
│ docs2db-mcp-server │
│ │
│ FastMCP Server │
│ └─ search_documents (tool) │
│ ↓ │
│ UniversalRAGEngine │
│ (from docs2db-api) │
└──────────────┬──────────────────────┘
│
↓
┌─────────────────────────────────────┐
│ PostgreSQL + pgvector │
│ (docs2db RAG database) │
└─────────────────────────────────────┘
Apache License 2.0 - See LICENSE for details.
Contributions welcome! Please open an issue or pull request.
Выполни в терминале:
claude mcp add docs2db-mcp-server -- npx Web content fetching and conversion for efficient LLM usage.
Retrieval from AWS Knowledge Base using Bedrock Agent Runtime.
автор: modelcontextprotocolProvides auto-configuration for setting up an MCP server in Spring Boot applications.
A very streamlined mcp client that supports calling and monitoring stdio/sse/streamableHttp, and can also view request responses through the /logs page. It also
автор: xuzexin-hzНе уверен что выбрать?
Найди свой стек за 60 секунд
Автор?
Embed-бейдж для README
Похожее
Все в категории ai