Readwise Vector DB MCP Server
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., "@Readwise Vector DB MCP Serverfind highlights about machine learning"
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.
Readwise Vector DB – Self-host your reading highlights search
Turn your Readwise library into a blazing-fast semantic search engine – complete with nightly syncs, vector search API, Prometheus metrics, and a streaming MCP server for LLM clients.
Table of Contents
Quick Start
# ❶ Clone & install
git clone https://github.com/leonardsellem/readwise-vector-db.git
cd readwise-vector-db
poetry install --sync
# ❷ Boot DB & run the API (localhost:8000)
docker compose up -d db
poetry run uvicorn readwise_vector_db.api:app --reload
# ❸ Verify
curl http://127.0.0.1:8000/health # → {"status":"ok"}
open http://127.0.0.1:8000/docs # interactive swagger UITip: Codespaces user? Click "Run → Open in Browser" after step ❷.
Using Supabase Cloud
Skip the local Docker setup and use a managed PostgreSQL with pgvector support:
# ❶ Create Supabase project at https://supabase.com/dashboard
# ❷ Enable pgvector extension in SQL Editor:
# CREATE EXTENSION IF NOT EXISTS vector;
# ❸ Set up environment
export DB_BACKEND=supabase
export SUPABASE_DB_URL="postgresql://postgres:[password]@db.[project].supabase.co:6543/postgres?options=project%3D[project]"
export READWISE_TOKEN=xxxx
export OPENAI_API_KEY=sk-...
# ❹ Run migrations and start the API
poetry run alembic upgrade head
poetry run uvicorn readwise_vector_db.api:app --reload
# ❺ Initial sync
poetry run rwv sync --backfill⚠️ Fail-fast behavior: The application will raise
ValueErrorimmediately on startup ifSUPABASE_DB_URLis missing whenDB_BACKEND=supabase.
Environment Variables Required:
DB_BACKEND=supabase– Switches from local Docker to SupabaseSUPABASE_DB_URL– Full PostgreSQL connection string from Supabase dashboardStandard variables:
READWISE_TOKEN,OPENAI_API_KEY
Benefits:
✅ No Docker setup required
✅ Managed backups and scaling
✅ Built-in pgvector support
✅ Global edge network
✅ SSE streaming optimized – Connection pooling and sub-100ms query latency
Deploy to Vercel in 3 Commands
Deploy the FastAPI app as a serverless function with Supabase backend:
# ❶ Set up Vercel project
npm install -g vercel
vercel login
vercel link # or vercel --confirm for new project
# ❶ Configure environment variables in Vercel dashboard or CLI:
vercel env add SUPABASE_DB_URL
vercel env add READWISE_TOKEN
vercel env add OPENAI_API_KEY
# ❸ Deploy
vercel --prodAutomatic Configuration:
DEPLOY_TARGET=vercel– Automatically set by Vercel environmentDB_BACKEND=supabase– Pre-configured invercel.jsonBuild process uses optimized
vercel_build.shscript
Resource Limits:
⏱️ Build timeout: 90 seconds
💾 Memory limit: 1024MB during build
🚀 Function timeout: 30 seconds per request
SSE Streaming Support:
✅ HTTP-based MCP Server –
/mcp/streamendpoint works seamlessly✅ Real-time search results – Server-Sent Events for streaming responses
✅ Cold-start optimized – Sub-1s initialization, auto-scaling connections
✅ HTTP/2 multiplexing – Unlimited concurrent connections per client
GitHub Integration:
Tagged releases (
v*.*.*) automatically deploy to productionPull requests create preview deployments
CI validates both Docker and Vercel builds
💡 Pro tip: Use
vercel --prebuiltfor faster subsequent deployments.
Why SSE for MCP in Serverless?
Traditional TCP MCP servers don't work in serverless environments because they require persistent connections. The HTTP-based MCP Server with Server-Sent Events (SSE) solves this by providing:
Feature | TCP MCP Server | HTTP SSE MCP Server |
Serverless Support | ❌ Requires persistent connections | ✅ Works on Vercel, Lambda, etc. |
Firewall/Proxy | ⚠️ May require custom ports | ✅ Standard HTTP/HTTPS (80/443) |
Browser Support | ❌ No native support | ✅ EventSource API built-in |
Auto-scaling | ⚠️ Limited by connection pooling | ✅ Infinite scaling via HTTP infrastructure |
Cold Starts | ❌ Connection drops during restarts | ✅ Stateless, reconnects automatically |
HTTP/2 Benefits | ❌ Not applicable | ✅ Multiplexing, header compression |
Use the SSE endpoint for production deployments on cloud platforms. The TCP server remains available for local development and dedicated server deployments.
📚 Comprehensive deployment guide: See docs/deployment-sse.md for detailed platform-specific instructions, troubleshooting, and performance tuning.
Detailed Setup
Prerequisites
• Python 3.12 | Poetry ≥ 1.8 | Docker + Compose
Environment Variables
Create .env (see .env.example) – minimal:
READWISE_TOKEN=xxxx # get from readwise.io/api_token
OPENAI_API_KEY=sk-...
DATABASE_URL=postgresql+asyncpg://rw_user:rw_pass@localhost:5432/readwiseAll variables are documented in docs/env.md.
Database & Migrations
docker compose up -d db # Postgres 16 + pgvector
poetry run alembic upgrade headSync Commands (CLI)
# first-time full sync
poetry run rwv sync --backfill
# daily incremental (fetch since yesterday)
poetry run rwv sync --since $(date -Idate -d 'yesterday')Usage Examples
Vector Search (HTTP API)
curl -X POST http://127.0.0.1:8000/search \
-H 'Content-Type: application/json' \
-d '{
"q": "Large Language Models",
"k": 10,
"filters": {
"source": "kindle",
"tags": ["ai", "research"],
"highlighted_at": ["2024-01-01", "2024-12-31"]
}
}'Streaming Search (HTTP SSE)
# Real-time streaming via Server-Sent Events (serverless-friendly)
curl -N -H "Accept: text/event-stream" \
"http://127.0.0.1:8000/mcp/stream?q=neural+networks&k=10"Streaming Search (MCP TCP)
poetry run python -m readwise_vector_db.mcp --host 0.0.0.0 --port 8375 &
# then from another shell
printf '{"jsonrpc":"2.0","id":1,"method":"search","params":{"q":"neural networks"}}\n' | \
nc 127.0.0.1 8375💡 New: Check out the SSE Usage Guide for JavaScript, Python, and browser examples!
Architecture Overview
The system supports multiple deployment patterns to fit different infrastructure needs:

Docker + Local PostgreSQL (Default)
flowchart TB
subgraph "🐳 Docker Deployment"
subgraph Ingestion
A[Readwise API] --> B[Backfill Job]
C[Nightly Cron] --> D[Incremental Job]
end
B --> E[OpenAI Embeddings]
D --> E
E --> F[Local PostgreSQL + pgvector]
F --> G[FastAPI Container]
G --> H[MCP Server :8375]
G --> I[Prometheus /metrics]
endVercel + Supabase (Cloud)
flowchart TB
subgraph Serverless_Deployment
subgraph Vercel_Edge
J[FastAPI Serverless]
K[/health endpoint/]
L[/search endpoint/]
M[/docs Swagger UI/]
J --> K
J --> L
J --> M
end
subgraph Supabase_Cloud
N[Managed PostgreSQL]
O[pgvector Extension]
P[Automated Backups]
N --> O
P --> N
end
J -.-> N
Q[GitHub Actions]
R[Auto Deploy on Tags]
Q --> R
R --> J
endKey Differences:
Docker: Full control, local data, requires infrastructure management
Vercel + Supabase: Zero-ops, global edge deployment, managed scaling
Hybrid: Use Supabase with local Docker for development → production consistency
Documentation:
Development & Contribution
Environment
poetry install --with dev poetry run pre-commit install # black, isort, ruff, mypy, markdownlintRun tests & coverage
poetry run coverage run -m pytest && coverage reportPerformance check (
make perf) – fails if/searchP95 >500 ms.Branching model: feature/xyz → PR → squash-merge. Use Conventional Commits (
feat:,fix:…).Coding style: see
.editorconfigand enforced linters.
See CONTRIBUTING.md for full guidelines.
Maintainer Notes
CI/CD –
.github/workflows/ci.ymlruns lint, type-check, tests (Py 3.11 + 3.12) and publishes images to GHCR.Back-ups –
pg_dumpweekly cron uploads compressed dump as artifact (Goal G4).Releasing – bump version in
pyproject.toml, runmake release.
License & Credits
Code licensed under the MIT License. Made with ❤️ by the community, powered by FastAPI, SQLModel, pgvector, OpenAI and Taskmaster-AI.
This server cannot be installed
Maintenance
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/leonardsellem/readwise-vector-db'
If you have feedback or need assistance with the MCP directory API, please join our Discord server