Web Search 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., "@Web Search MCP Serversearch for latest AI trends in healthcare"
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.
Web Search MCP Server
A production-ready Model Context Protocol (MCP) Server that acts as a universal web search and content retrieval tool for AI agents.
Features
🔍 Universal search — any topic, any language query
🌐 Multi-provider — Tavily, Brave, Bing, SerpAPI, Google CSE (pluggable)
📄 Content extraction — HTTP + BeautifulSoup (primary), Playwright (fallback for SPAs)
⚡ Async-first — parallel page fetching, connection pooling
🗃️ Caching — in-memory TTL cache to save API quota
🔄 Retry logic — exponential back-off via tenacity
📊 Structured JSON — Pydantic v2 models, MCP-compliant output
🪵 Structured logging — JSON or text format
Related MCP server: Crawl4AI+SearXNG MCP Server
Project Structure
web_search_mcp/
│
├── server.py ← FastMCP server + tool registration
├── tools.py ← Tool orchestration (search → extract → rank)
├── search.py ← Pluggable search providers
├── extractor.py ← HTML content extraction (BS4 + Playwright)
├── browser.py ← Playwright browser manager
├── models.py ← Pydantic data models
├── config.py ← Settings (pydantic-settings + .env)
├── logger.py ← Structured logging
├── utils.py ← Shared helpers
├── requirements.txt
├── .env ← Configuration (fill in your API keys)
└── README.mdQuick Start
1. Prerequisites
Python 3.11 or higher
pip
2. Install Dependencies
pip install -r requirements.txt3. Install Playwright Browser
playwright install chromiumThis downloads the Chromium binary (~130 MB). Required for JavaScript-heavy page extraction.
4. Configure API Keys
Edit .env and add at least one search provider key:
SEARCH_PROVIDER=tavily
TAVILY_API_KEY=your_key_hereGetting a free Tavily key (recommended):
Visit app.tavily.com
Sign up for a free account
Copy your API key → paste into
.env
5. Run the Server
python server.pyThe server starts in STDIO mode (default), ready to connect with any MCP client.
MCP Tools
web_search
Search the web and return ranked snippets (no page visits).
Input:
{
"query": "Latest AI trends in healthcare",
"max_results": 10
}Output:
{
"query": "Latest AI trends in healthcare",
"total_results": 10,
"search_provider": "tavily",
"results": [
{
"title": "AI in Healthcare 2025",
"url": "https://example.com/ai-health",
"domain": "example.com",
"snippet": "Short summary of the article...",
"content": "Same as snippet for web_search",
"published_date": "2025-06-15",
"relevance_score": 0.92
}
],
"cached": false,
"execution_time_ms": 312.5
}webpage_content
Extract full readable content from a specific URL.
Input:
{
"url": "https://example.com/article",
"use_browser": false
}Set use_browser: true to force Playwright rendering for JavaScript-heavy pages.
search_and_extract
End-to-end: search → visit pages → extract content → rank results.
Input:
{
"query": "Latest UK visa requirements 2025",
"max_results": 5,
"use_browser_fallback": true
}Returns full page content for each result including title, author, publish date, and extracted text.
Search Providers
Provider | Env Key | Free Tier | Notes |
Tavily ⭐ |
| 1,000/month | Best snippets, recommended |
Brave |
| 2,000/month | Privacy-focused |
Bing |
| 1,000/month | Azure Cognitive Services |
SerpAPI |
| 100/month | Proxies Google |
Google CSE |
| 100/day | Custom Search Engine |
Switch provider by changing SEARCH_PROVIDER in .env.
Configuration Reference
Setting | Default | Description |
|
| Active search backend |
|
| Default result count |
|
| HTTP timeout (seconds) |
|
| Parallel page extractions |
|
| Cache time-to-live (seconds, 0 = disabled) |
|
| Max cache entries |
|
| Headless browser mode |
|
| Browser nav timeout (ms) |
|
| Max HTTP retry attempts |
|
| Logging verbosity |
|
|
|
Connecting with MCP Clients
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"web-search": {
"command": "python",
"args": ["C:/path/to/websearchMcp/server.py"],
"env": {
"TAVILY_API_KEY": "your_key_here"
}
}
}
}Custom MCP Client (Python)
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
server_params = StdioServerParameters(
command="python",
args=["server.py"],
)
async with stdio_client(server_params) as (read, write):
async with ClientSession(read, write) as session:
await session.initialize()
result = await session.call_tool(
"search_and_extract",
{"query": "Latest AI trends", "max_results": 3}
)
print(result)Architecture
User Query
│
▼
FastMCP Server (server.py)
│ validates input (Pydantic)
▼
Tool Orchestrator (tools.py)
│ checks cache → calls provider
▼
Search Provider (search.py)
│ Tavily / Brave / Bing / SerpAPI / Google
▼
Raw Search Results
│
▼
Content Extractor (extractor.py)
│ HTTP + BS4 → Playwright fallback
▼
Cleaned & Ranked Results
│
▼
Structured JSON ResponseError Handling
All tools return structured error JSON on failure:
{
"error": "No API key configured for provider 'tavily'",
"error_type": "RuntimeError",
"tool": "web_search",
"query": "AI trends",
"timestamp": "2025-06-30T18:00:00Z"
}Performance Tips
Use
web_searchwhen you only need snippets (faster, uses less quota).Use
search_and_extractfor deep research requiring full article content.Increase
CONCURRENCY_LIMITfor faster parallel extraction (be mindful of rate limits).Increase
CACHE_TTLto reduce repeated API calls for the same queries.Set
PLAYWRIGHT_HEADLESS=true(default) in production.
Deploying to Render
Push the repo to GitHub (
.envis git-ignored — API keys are safe)Go to render.com → New → Blueprint → connect repo
Render detects
render.yamlautomaticallySet
TAVILY_API_KEYin Render dashboard → Environment VariablesYour SSE endpoint:
https://your-app.onrender.com/sse
Deploying to Azure Container Apps
Prerequisites:
Azure CLI:
winget install Microsoft.AzureCLIAzure account with active subscription
One-command deploy:
# 1. Login to Azure
az login
# 2. Run the deployment script (reads TAVILY_API_KEY from .env automatically)
.\deploy-azure.ps1The script will:
Create a Resource Group + Azure Container Registry
Build and push the Docker image via ACR Tasks (builds in Azure cloud — no local build needed)
Create a Container Apps Environment
Deploy the MCP server with your Tavily key stored as a secret (never in plain text)
Print your live SSE endpoint URL
Custom options:
.\deploy-azure.ps1 `
-ResourceGroup "my-rg" `
-Location "westeurope" `
-AppName "my-mcp-server" `
-Cpu "2.0" `
-Memory "4.0Gi"Add to your no-code platform after deploy:
Field | Value |
Transport |
|
URL |
|
Health check: https://<your-app>.<region>.azurecontainerapps.io/health
Update after code changes:
# Just re-run the deploy script — it rebuilds and redeploys
.\deploy-azure.ps1License
MIT
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
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/lalit9168/websearchMcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server