The OneSearch MCP Server is a versatile tool for web search, scraping, crawling, and structured data extraction, integrating multiple search providers and browser automation.
Web Search (: Search using SearXNG, Tavily, DuckDuckGo, Bing, Google, Zhipu, Exa, Bocha, or local browser automation (Bing, Google, Baidu, Sogou). Supports filtering by language, time range, and categories (news, images, videos, science, etc.).
Web Scraping (: Scrape single pages with output in markdown, HTML, raw HTML, screenshots, or links. Supports browser actions (click, scroll, type, execute JavaScript), mobile viewport emulation, and geolocation settings.
URL Discovery (: Discover URLs from a starting point via sitemap.xml and/or HTML link crawling, with options to filter by search term, include subdomains, and limit results.
Structured Data Extraction (: Extract structured information from multiple URLs simultaneously using LLM-powered extraction with custom prompts, JSON schemas, and optional web search context.
Local/Free Operation: Run browser-automated searches and scraping without API keys using
agent-browser(requires a Chromium-based browser), ensuring privacy and no API costs.Multi-provider Flexibility: Easily switch between free (DuckDuckGo, local) and premium (Tavily, Exa, Bocha, Zhipu) providers via environment variables. Available via npm, Docker, and compatible with Claude Desktop, Cursor, and Windsurf.
Used for installation and distribution of the MCP server package, with support for running the server through npx commands.
Enables web search capabilities through SearXNG, allowing queries to be performed across multiple search engines through a single interface.
Supports installation and execution through shell commands, with environment variable configuration for different search providers and APIs.
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., "@OneSearch MCP Serverfind recent articles about quantum computing breakthroughs"
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.
🚀 OneSearch MCP Server: Web Search & Crawl & Scraper & Extract
A Model Context Protocol (MCP) server implementation that integrates with multiple search providers for web search, local browser search, and scraping capabilities with agent-browser.
Features
Web Search, scrape, crawl and extract content from websites.
Support multiple search engines and web scrapers: SearXNG, Tavily, DuckDuckGo, Bing, Google, Zhipu (智谱), Exa, Bocha (博查), etc.
Local web search (browser search), support multiple search engines: Bing, Google, Baidu, Sogou, etc.
Use
agent-browserfor browser automation.Free, no API keys required.
Enabled tools:
one_search,one_scrape,one_map,one_extract
Related MCP server: Firecrawl MCP Server
Migration from v1.1.0 and Earlier
Breaking Changes in v1.1.0:
Firecrawl Removed: The Firecrawl integration has been removed in favor of
agent-browser, which provides similar functionality without requiring external API services.New Browser Requirement: You must install Chromium browser (see Prerequisites section).
Environment Variables:
FIRECRAWL_API_URLandFIRECRAWL_API_KEYare no longer used.
What Changed:
one_scrapeandone_mapnow useagent-browserinstead of Firecrawlone_extracttool is now fully implemented for structured data extraction from multiple URLsAll browser-based operations are now handled locally, providing better privacy and no API costs
Migration Steps:
Install Chromium browser (see Prerequisites)
Remove
FIRECRAWL_API_URLandFIRECRAWL_API_KEYfrom your environment variablesUpdate to the latest version:
npm install -g one-search-mcp@latest
Prerequisites
Browser Requirement: This server uses agent-browser for web scraping and local search, which requires a Chromium-based browser.
Good News: The server will automatically detect and use browsers already installed on your system:
✅ Google Chrome
✅ Microsoft Edge
✅ Chromium
✅ Google Chrome Canary
If you don't have any of these browsers installed, you can:
# Option 1: Install Google Chrome (Recommended)
# Download from: https://www.google.com/chrome/
# Option 2: Install Microsoft Edge
# Download from: https://www.microsoft.com/edge
# Option 3: Install Chromium via agent-browser
npx agent-browser install
# Option 4: Install Chromium directly
# Download from: https://www.chromium.org/getting-involved/download-chromium/Installation
Using Claude Code CLI (Recommended)
# Add to Claude Code with default settings (local search)
claude mcp add one-search-mcp -- npx -y one-search-mcp
# Add with custom search provider (e.g., SearXNG)
claude mcp add one-search-mcp -e SEARCH_PROVIDER=searxng -e SEARCH_API_URL=http://127.0.0.1:8080 -- npx -y one-search-mcp
# Add with Tavily API
claude mcp add one-search-mcp -e SEARCH_PROVIDER=tavily -e SEARCH_API_KEY=your_api_key -- npx -y one-search-mcpManual Installation
# Install globally (Optional)
npm install -g one-search-mcp
# Or run directly with npx
npx -y one-search-mcpUsing Docker
Docker image includes all dependencies (Chromium browser) pre-installed, no additional setup required.
Pull the image:
# From GitHub Container Registry
docker pull ghcr.io/yokingma/one-search-mcp:latest
# Or from Docker Hub
docker pull zacma/one-search-mcp:latestConfigure with Claude Desktop:
{
"mcpServers": {
"one-search-mcp": {
"command": "docker",
"args": ["run", "-i", "--rm", "ghcr.io/yokingma/one-search-mcp:latest"],
"env": {
"SEARCH_PROVIDER": "local"
}
}
}
}With custom search provider:
{
"mcpServers": {
"one-search-mcp": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"-e", "SEARCH_PROVIDER=tavily",
"-e", "SEARCH_API_KEY=your_api_key",
"ghcr.io/yokingma/one-search-mcp:latest"
]
}
}
}Environment Variables
Search Engine:
SEARCH_PROVIDER (Optional): The search provider to use, supports
searxng,duckduckgo,bing,tavily,google,zhipu,exa,bocha,local, default islocal.SEARCH_API_URL (Optional): The URL of the SearxNG API, or Google Custom Search Engine ID for
google.SEARCH_API_KEY (Optional): The API key for the search provider, required for
tavily,bing,google,zhipu,exa,bocha.
// supported search providers
export type SearchProvider = 'searxng' | 'duckduckgo' | 'bing' | 'tavily' | 'google' | 'zhipu' | 'exa' | 'bocha' | 'local';Search Provider Configuration
Provider | API Key Required | API URL Required | Notes |
| No | No | Free, uses browser automation |
| No | No | Free, no API key needed |
| Optional | Yes | Self-hosted meta search engine |
| Yes | No | |
| Yes | No | |
| Yes | Yes (Search Engine ID) | |
| Yes | No | |
| Yes | No | |
| Yes | No |
Configuration for Other MCP Clients
Claude Desktop
Add to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"one-search-mcp": {
"command": "npx",
"args": ["-y", "one-search-mcp"],
"env": {
"SEARCH_PROVIDER": "local"
}
}
}
}Cursor
Add to your mcp.json file:
{
"mcpServers": {
"one-search-mcp": {
"command": "npx",
"args": ["-y", "one-search-mcp"],
"env": {
"SEARCH_PROVIDER": "local"
}
}
}
}Windsurf
Add to your ./codeium/windsurf/model_config.json file:
{
"mcpServers": {
"one-search-mcp": {
"command": "npx",
"args": ["-y", "one-search-mcp"],
"env": {
"SEARCH_PROVIDER": "local"
}
}
}
}Self-hosting SearXNG (Optional)
If you want to use SearXNG as your search provider, you can deploy it locally using Docker:
Prerequisites:
Docker installed and running (version 20.10.0 or higher)
At least 4GB of RAM available
Quick Start:
# Clone SearXNG Docker repository
git clone https://github.com/searxng/searxng-docker.git
cd searxng-docker
# Start SearXNG
docker compose up -dAfter deployment, SearXNG will be available at http://127.0.0.1:8080 by default.
Configure OneSearch to use SearXNG:
# Set environment variables
export SEARCH_PROVIDER=searxng
export SEARCH_API_URL=http://127.0.0.1:8080For more details, see the official SearXNG Docker documentation.
Troubleshooting
Browser not found error
If you see an error like "Browser not found", the server couldn't detect any installed Chromium-based browser. Please install one of the following:
Google Chrome: https://www.google.com/chrome/
Microsoft Edge: https://www.microsoft.com/edge
Chromium: https://www.chromium.org/getting-involved/download-chromium/
Or install via agent-browser:
npx agent-browser installLicense
MIT License - see LICENSE file for details.