JUHE API Marketplace
datalayer avatar
MCP Server

Earthdata MCP Server

A Model Context Protocol server that enables efficient discovery and retrieval of NASA Earth Data for geospatial analysis.

27
GitHub Stars
6/25/2026
Last Updated
MCP Server Configuration
1{
2 "name": "earthdata",
3 "command": "docker",
4 "args": [
5 "run",
6 "-i",
7 "--rm",
8 "datalayer/earthdata-mcp-server:latest"
9 ],
10 "env": {
11 "EARTHDATA_USERNAME": "your_username",
12 "EARTHDATA_PASSWORD": "your_password"
13 }
14}
JSON14 lines
  1. Home
  2. MCP Servers
  3. earthdata-mcp-server

README Documentation

Datalayer

🪐 ✨ Earthdata MCP Server

smithery badge Unit Tests Lint and Type Check

Earthdata MCP Server is a Model Context Protocol (MCP) server implementation that provides tools to interact with NASA Earth Data.

This server is intentionally Earthdata-only.

If you need notebook/runtime tools, compose this server with jupyter-mcp-server using mcp-compose.

Key Features

  • Dataset discovery on NASA Earthdata
  • Granule search with temporal and bounding box filters
  • Flexible download workflow with explicit execution modes

Analyzing Sea Level Rise with AI-Powered Geospatial Tools and Jupyter - Watch Video

Getting Started

Local install

pip install earthdata-mcp-server

Docker with Claude Desktop

{
  "mcpServers": {
    "earthdata": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "datalayer/earthdata-mcp-server:latest"
      ],
      "env": {
        "EARTHDATA_USERNAME": "your_username",
        "EARTHDATA_PASSWORD": "your_password"
      }
    }
  }
}

Linux host networking

{
  "mcpServers": {
    "earthdata": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "--network=host",
        "datalayer/earthdata-mcp-server:latest"
      ],
      "env": {
        "EARTHDATA_USERNAME": "your_username",
        "EARTHDATA_PASSWORD": "your_password"
      }
    }
  }
}

Tools

The server offers 3 Earthdata tools.

search_earth_datasets

  • Search for datasets on NASA Earthdata.
  • Input:
    • search_keywords (str): Keywords to search for in the dataset titles.
    • count (int): Number of datasets to return.
    • temporal (tuple): (Optional) Temporal range in the format (date_from, date_to).
    • bounding_box (tuple): (Optional) Bounding box in the format (lower_left_lon, lower_left_lat, upper_right_lon, upper_right_lat).
  • Returns: List of dataset abstracts.

search_earth_datagranules

  • Search for data granules on NASA Earthdata.
  • Input:
    • short_name (str): Short name of the dataset.
    • count (int): Number of data granules to return.
    • temporal (tuple): (Optional) Temporal range in the format (date_from, date_to).
    • bounding_box (tuple): (Optional) Bounding box in the format (lower_left_lon, lower_left_lat, upper_right_lon, upper_right_lat).
  • Returns: List of data granules.

download_earth_data_granules

  • Search and optionally download granules with explicit modes.
  • Authentication: Requires NASA Earthdata Login credentials (see authentication guide)
  • Input:
    • folder_name (str): Local folder name to save the data.
    • short_name (str): Short name of the Earth dataset to download.
    • count (int): Number of data granules to download.
    • temporal (tuple): (Optional) Temporal range in the format (date_from, date_to).
    • bounding_box (tuple): (Optional) Bounding box in the format (lower_left_lon, lower_left_lat, upper_right_lon, upper_right_lat).
    • mode (str): One of:
      • manifest: Returns granule metadata only.
      • download: Downloads files directly on server side.
      • script: Returns Python code to execute elsewhere.
    • max_manifest_items (int): Max items returned in manifest mode.
How download works

download_earth_data_granules always starts by searching for granules with your filters, then behaves based on mode:

  1. manifest
    • Returns a structured preview (items) with IDs, titles, and links.
    • Does not write files.
    • Best first step for validating query scope.
  2. download
    • Authenticates with Earthdata using environment credentials.
    • Downloads matching granules directly to folder_name on the server runtime.
    • Returns downloaded file paths.
  3. script
    • Returns executable Python code that performs the same search + download.
    • Best option when execution should happen in a notebook/runtime controlled by another MCP server.
Recommended download strategy
  1. Use mode="manifest" first to inspect results safely.
  2. Use mode="script" when you want notebook-driven execution via mcp-compose + jupyter-mcp-server.
  3. Use mode="download" only when server-side file writes are intended.

For a full composition example with mcp-compose, see download workflow docs.

Prompts

  1. download_analyze_global_sea_level

    • Generates a workflow that starts with download_earth_data_granules in script mode.
    • Intended to be executed in a composed notebook/runtime stack (via mcp-compose).
  2. sealevel_rise_dataset

    • Search for datasets related to sea level rise worldwide.
    • Input:
      • start_year (int): Start year to consider.
      • end_year (int): End year to consider.
    • Returns: Prompt correctly formatted.
  3. ask_datasets_format

    • To ask about the format of the datasets.
    • Returns: Prompt correctly formatted.

Building

# or run `docker build -t datalayer/earthdata-mcp-server .`
make build-docker

If you prefer, you can pull the prebuilt images.

make pull-docker

Quick Install

Quick Actions

View on GitHubView All Servers

Key Features

Model Context Protocol
Secure Communication
Real-time Updates
Open Source

Boost your projects with Wisdom Gate LLM API

Supporting GPT-5, Claude-4, DeepSeek v3, Gemini and more.

Enjoy a free trial and save 20%+ compared to official pricing.

Learn More
JUHE API Marketplace

Accelerate development, innovate faster, and transform your business with our comprehensive API ecosystem.

JUHE API VS

  • vs. RapidAPI
  • vs. API Layer
  • API Platforms 2025
  • API Marketplaces 2025
  • Best Alternatives to RapidAPI

For Developers

  • Console
  • Collections
  • Documentation
  • MCP Servers
  • Free APIs
  • Temp Mail Demo

Product

  • Browse APIs
  • Suggest an API
  • Wisdom Gate LLM
  • Global SMS Messaging
  • Temp Mail API

Company

  • What's New
  • Welcome
  • About Us
  • Contact Support
  • Terms of Service
  • Privacy Policy
Featured on Startup FameFeatured on Twelve ToolsFazier badgeJuheAPI Marketplace - Connect smarter, beyond APIs | Product Huntai tools code.marketDang.aiFeatured on ShowMeBestAI
Copyright © 2026 JUHEDATA HK LIMITED - All rights reserved