searxng-mcp
An MCP server for SearXNG that provides web search capabilities with concise model-visible output while preserving full result payloads in metadata. It supports search, parallel fetching, URL extraction, and research workflows through both local stdio and streamable HTTP transports.
README
searxng-mcp
An MCP server for SearXNG that keeps the model-visible output short, preserves full result payloads in hidden metadata, and supports both local stdio clients and deployed streamable-http use.
What you get
searchfor concise web search with full raw payloads in_metasearch_manyfor parallel fan-out, dedupe, and merged rankingsearch_and_fetchfor search plus source extraction in one callresearchfor multi-query search with batch fetches and merged sourcesfetch_urlfor readable page extraction with citationsfetch_manyfor parallel URL extraction with cachinghealthfor backend, cache, and render status
The server is designed to be thin. SearXNG does the search work; searxng-mcp handles tool shaping, caching, extraction, and transport.
Quick Start
Install from a checkout
uv sync
uv run searxng-mcp
Install with uvx
searxng-mcp is distributed from this repository (no PyPI release). The shortest path is:
uvx --from git+https://github.com/88plug/searxng-mcp searxng-mcp
For rendered fetch support, request the render extra:
uvx --from "searxng-mcp[render] @ git+https://github.com/88plug/searxng-mcp" searxng-mcp
Run with Docker
docker build -t searxng-mcp .
docker run --rm -p 8811:8811 --add-host=host.docker.internal:host-gateway \
-e SEARXNG_MCP_BASE_URL=http://host.docker.internal:8890 \
searxng-mcp
Claude Desktop example
{
"mcpServers": {
"searxng-mcp": {
"command": "uvx",
"args": ["--from", "git+https://github.com/88plug/searxng-mcp", "searxng-mcp"],
"env": {
"SEARXNG_MCP_BASE_URL": "http://127.0.0.1:8890",
"SEARXNG_MCP_TRANSPORT": "stdio"
}
}
}
}
Deployment Modes
Local stdio
Use this for desktop clients and private workflows. It is the simplest and safest mode.
SEARXNG_MCP_TRANSPORT=stdio uv run searxng-mcp
Streamable HTTP
Use this for a private service, a team deployment, or a reverse-proxied internal endpoint.
SEARXNG_MCP_TRANSPORT=streamable-http uv run searxng-mcp --host 0.0.0.0 --port 8811
Hardened Docker and Compose
For a longer-running self-hosted service, use the hardened container variant and the provided Compose stack.
docker build -f Dockerfile.prod -t searxng-mcp:prod .
cp docker-compose.env.example .env
docker compose up --build -d
Security and Trust
This project is safe for local and trusted-network use. It is not a drop-in public Internet service.
fetch_urlandfetch_manycan fetch arbitrary URLs supplied by the client- rendered extraction may launch Chromium against untrusted pages
streamable-httpshould be put behind auth or a reverse proxy for any shared deploymentSEARXNG_MCP_FETCH_VERIFY_TLS=0is only for private or self-signed backend setups
If you expose the HTTP transport, treat it like an internal service and add the controls you would expect for any SSRF-capable tool.
Why This Exists
- compact model-visible output, with full details preserved in hidden metadata
- faster research workflows through parallel search and fetch fan-out
- optional rendered extraction for JS-heavy pages
- self-hostable deployment for people who want their own SearXNG-backed MCP server
MCP Surface
searxng://configexposes current settings, transport mode, and render supportsearxng://guidesummarizes the available tools and when to use themquick_lookup,deep_research, andresearch_workfloware optional compatibility prompts for clients that support prompt surfaces
Environment
Key variables:
SEARXNG_MCP_BASE_URL: SearXNG base URL, defaulthttp://127.0.0.1:8890SEARXNG_MCP_FALLBACK_BASE_URLS: optional comma-separated fallback SearXNG instancesSEARXNG_MCP_TRANSPORT:stdio,streamable-http, orsseSEARXNG_MCP_SEARCH_TIMEOUT: backend search timeout in secondsSEARXNG_MCP_FETCH_TIMEOUT: fetch timeout in secondsSEARXNG_MCP_SEARCH_CACHE_TTL: search cache TTL in secondsSEARXNG_MCP_FETCH_CACHE_TTL: fetch cache TTL in secondsSEARXNG_MCP_FETCH_VERIFY_TLS: set to0to skip TLS verification on fetchesSEARXNG_MCP_RENDER_TIMEOUT: browser navigation timeout for rendered fetchesSEARXNG_MCP_RENDER_WAIT_MS: extra wait after DOM content load for rendered fetchesSEARXNG_MCP_RENDER_CONCURRENCY: concurrent rendered fetch limitSEARXNG_MCP_RENDER_HEADLESS: set to0to show the browserSEARXNG_MCP_RENDER_BROWSER_PATH: explicit Chromium or Chrome binary pathSEARXNG_MCP_RENDER_SANDBOX: set to1to keep Chromium sandboxing enabledSEARXNG_MCP_RENDER_BLOCK_RESOURCES: set to0to allow images, fonts, stylesheets, and media during renderSEARXNG_MCP_RENDER_AUTO_FALLBACK: set to0to disable automatic rendered fallbackSEARXNG_MCP_RENDER_AUTO_MIN_WORDS: lower this to make auto-render more aggressiveSEARXNG_MCP_RENDER_AUTO_MIN_CHARS: lower this to make auto-render more aggressiveSEARXNG_MCP_CACHE_DIR: cache directory path
Benchmarks
uv run searxng-mcp-bench --rounds 3
The benchmark reports:
- raw SearXNG backend latency
- token-visible search output size
- merged multi-query search latency
- multi-query research latency
- fetch extraction latency
- rendered fetch latency
- batch fetch extraction latency
- rendered batch fetch latency
Documentation
- Docs site overview
- Getting started
- Deployment
- Security
- Tool reference
- Client configs
- Comparison
- Changelog
- SearXNG docs
Build and Test
uv sync --all-groups
uv run pytest -q
uv run python -m compileall src
uv run mkdocs build --strict
Dependency Maintenance
Manual checks:
uv lock --upgrade --dry-run
uvx --from pip-audit pip-audit
Automated checks:
- weekly Dependabot PRs for
uvdependencies and GitHub Actions - weekly
Dependency Healthworkflow for vulnerability scanning and upgrade dry runs
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.