Weather MCP Server

Weather MCP Server

Provides real-time weather forecasts and alerts for US locations using the National Weather Service API. Supports querying forecasts by coordinates and retrieving active weather alerts by state.

Category
Visit Server

README

Weather MCP Server

A Model Context Protocol (MCP) server that provides weather information using the National Weather Service API. This server exposes tools for getting weather forecasts and alerts for US locations.

Features

  • šŸŒ¤ļø Weather Forecasts: Get detailed weather forecasts for any US location using latitude/longitude coordinates
  • 🚨 Weather Alerts: Retrieve active weather alerts for any US state
  • šŸ”Œ MCP Integration: Works seamlessly with Claude for Desktop and other MCP-compatible clients
  • šŸ“” Real-time Data: Fetches live data from the National Weather Service API

Tools Available

get-forecast

Get weather forecast for a specific location.

Parameters:

  • latitude (float): Latitude of the location (-90 to 90)
  • longitude (float): Longitude of the location (-180 to 180)

Example usage:

  • "What's the weather forecast for San Francisco?" (Claude will use coordinates ~37.7749, -122.4194)
  • "Give me the weather forecast for latitude 47.6062, longitude -122.3321" (Seattle)

get-alerts

Get active weather alerts for a US state.

Parameters:

  • state (string): Two-letter US state code (e.g., "CA", "NY", "TX")

Example usage:

  • "What are the active weather alerts in California?"
  • "Are there any weather warnings in Texas?"

Prerequisites

  • Python 3.10 or higher
  • uv package manager
  • Access to the internet (for NWS API calls)

Installation

  1. Install uv (if not already installed):

    # macOS/Linux
    curl -LsSf https://astral.sh/uv/install.sh | sh
    
    # Windows
    powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
    
  2. Clone or navigate to the project directory:

    cd weather
    
  3. Install dependencies:

    uv sync
    

Running the Server

Standalone Testing

To test the server directly:

uv run weather.py

The server will start and listen on standard input/output. You can test it using the MCP inspector or other MCP clients.

With Claude for Desktop

  1. Install Claude for Desktop from claude.ai/download

  2. Configure Claude for Desktop by editing the configuration file:

    macOS/Linux:

    code ~/Library/Application\ Support/Claude/claude_desktop_config.json
    

    Windows:

    code $env:AppData\Claude\claude_desktop_config.json
    
  3. Add the weather server configuration:

    macOS/Linux:

    {
      "mcpServers": {
        "weather": {
          "command": "uv",
          "args": [
            "--directory",
            "/ABSOLUTE/PATH/TO/YOUR/weather",
            "run",
            "weather.py"
          ]
        }
      }
    }
    

    Windows:

    {
      "mcpServers": {
        "weather": {
          "command": "uv",
          "args": [
            "--directory",
            "C:\\ABSOLUTE\\PATH\\TO\\YOUR\\weather",
            "run",
            "weather.py"
          ]
        }
      }
    }
    
  4. Restart Claude for Desktop completely

  5. Verify the integration by looking for the "Search and tools" icon in Claude for Desktop

Usage Examples

Once configured with Claude for Desktop, you can ask questions like:

  • "What's the weather forecast for Sacramento?"
  • "Give me the weather forecast for New York City"
  • "What are the active weather alerts in Florida?"
  • "Are there any severe weather warnings in Texas?"
  • "What's the weather like at coordinates 40.7128, -74.0060?" (NYC)

API Details

This server uses the National Weather Service API (api.weather.gov), which:

  • Provides free access to US weather data
  • Requires no API key
  • Returns data in JSON format
  • Only covers US locations

Project Structure

weather/
ā”œā”€ā”€ main.py          # Entry point (if needed)
ā”œā”€ā”€ weather.py       # Main MCP server implementation
ā”œā”€ā”€ pyproject.toml   # Project configuration and dependencies
ā”œā”€ā”€ uv.lock         # Dependency lock file
└── README.md       # This file

Troubleshooting

Server Not Showing Up in Claude

  1. Check the configuration file syntax - Ensure valid JSON

  2. Verify the absolute path - Use full paths, not relative ones

  3. Check Claude's logs:

    # macOS/Linux
    tail -f ~/Library/Logs/Claude/mcp*.log
    
    # Windows
    # Check logs in %AppData%\Claude\logs\
    
  4. Restart Claude for Desktop completely

Tool Calls Failing

  1. Verify the server runs standalone:
    uv run weather.py
    
  2. Check for rate limiting - The NWS API has rate limits
  3. Ensure coordinates are for US locations - The NWS API only covers the US
  4. Check internet connectivity - Server needs to reach api.weather.gov

Common Error Messages

  • "Failed to retrieve grid point data": Usually means coordinates are outside the US
  • "No active alerts for this state": Not an error - just means no current alerts
  • "Unable to fetch forecast data": Network issue or invalid coordinates

Development

Adding New Tools

To add new weather-related tools:

  1. Add the tool using the @mcp.tool() decorator
  2. Implement the async function with proper type hints
  3. Add error handling and validation
  4. Test with uv run weather.py

Dependencies

Key dependencies (managed by uv):

  • mcp: Model Context Protocol SDK
  • httpx: HTTP client for API requests
  • fastmcp: Simplified MCP server framework

License

This project is part of the Model Context Protocol ecosystem. Check individual dependencies for their licenses.

Contributing

Feel free to submit issues and pull requests to improve the weather server functionality.

Related Resources

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured