Track MCP LogoTrack MCP
Track MCP LogoTrack MCP

The world's largest repository of Model Context Protocol servers. Discover, explore, and submit MCP tools.

Product

  • Categories
  • Top MCP
  • New & Updated
  • Submit MCP

Company

  • About

Legal

  • Privacy Policy
  • Terms of Service
  • Cookie Policy

© 2026 TrackMCP. All rights reserved.

Built with ❤️ by Krishna Goyal

    Geoserver Mcp

    A Model Context Protocol (MCP) server implementation that connects LLMs to the GeoServer REST API

    40 stars
    Python
    Updated Oct 19, 2025

    Table of Contents

    • 🎥 Demo
    • 📋 Table of Contents
    • 🚀 Features
    • 📋 Prerequisites
    • 🛠️ Installation
    • Installing via Smithery
    • 🛠️ Installation (Docker)
    • 🛠️ Installation (pip)
    • 🛠️ Development installation
    • File Storage and --storage Usage
    • Overview
    • CLI Example
    • When Running in Docker
    • Best Practices
    • 🛠️ Available Tools
    • 🌍 Resource Endpoints
    • 📦 Workspace Management
    • 📁 Datastore & Coveragestore Management
    • 🗺️ Layer Management
    • 🧩 Layer Group Management
    • 👥 User & User Group Management
    • 📊 Feature Type & Attribute Management
    • 🎨 Style Management
    • ⚙️ System & Service Operations
    • 📝 Style XML Utilities
    • 🛠️ Client Development
    • List Workspaces
    • Get Layer Information
    • Query Features
    • Generate Map
    • 🔮 Planned Features
    • 🤝 Contributing
    • 📄 License
    • 🔗 Related Projects
    • 🌐 See Also: GIS MCP
    • 📞 Support
    • 🏆 Badges

    Table of Contents

    • 🎥 Demo
    • 📋 Table of Contents
    • 🚀 Features
    • 📋 Prerequisites
    • 🛠️ Installation
    • Installing via Smithery
    • 🛠️ Installation (Docker)
    • 🛠️ Installation (pip)
    • 🛠️ Development installation
    • File Storage and --storage Usage
    • Overview
    • CLI Example
    • When Running in Docker
    • Best Practices
    • 🛠️ Available Tools
    • 🌍 Resource Endpoints
    • 📦 Workspace Management
    • 📁 Datastore & Coveragestore Management
    • 🗺️ Layer Management
    • 🧩 Layer Group Management
    • 👥 User & User Group Management
    • 📊 Feature Type & Attribute Management
    • 🎨 Style Management
    • ⚙️ System & Service Operations
    • 📝 Style XML Utilities
    • 🛠️ Client Development
    • List Workspaces
    • Get Layer Information
    • Query Features
    • Generate Map
    • 🔮 Planned Features
    • 🤝 Contributing
    • 📄 License
    • 🔗 Related Projects
    • 🌐 See Also: GIS MCP
    • 📞 Support
    • 🏆 Badges

    Documentation

    PyPI Downloads

    GeoServer MCP Server

    A Model Context Protocol (MCP) server implementation that connects Large Language Models (LLMs) to the GeoServer REST API, enabling AI assistants to interact with geospatial data and services.

    Version 0.5.0 (Beta) is under active development and will be released shortly. We are open to contributions and welcome developers to join us in building this project.

    🎥 Demo

    📋 Table of Contents

    • Features
    • Prerequisites
    • Installation
    • Docker Installation
    • pip Installation
    • Development Installation
    • [File Storage and --storage Usage](#file-storage-and---storage-usage)
    • Available Tools
    • Resource Endpoints
    • Workspace Management
    • Datastore & Coveragestore Management
    • Layer Management
    • Layer Group Management
    • User & User Group Management
    • Feature Type & Attribute Management
    • Style Management
    • System & Service Operations
    • Style XML Utilities
    • Client Development
    • List Workspaces
    • Get Layer Information
    • Query Features
    • Generate Map
    • Planned Features
    • Contributing
    • License
    • Related Projects
    • Support
    • Badges

    🚀 Features

    • 🔍 Query and manipulate GeoServer workspaces, layers, and styles
    • 🗺️ Execute spatial queries on vector data
    • 🎨 Generate map visualizations
    • 🌐 Access OGC-compliant web services (WMS, WFS)
    • 🛠️ Easy integration with MCP-compatible clients

    📋 Prerequisites

    • Python 3.10 or higher
    • Running GeoServer instance with REST API enabled
    • MCP-compatible client (like Claude Desktop or Cursor)
    • Internet connection for package installation

    🛠️ Installation

    Choose the installation method that best suits your needs:

    Installing via Smithery

    To install GeoServer MCP Server for Claude Desktop automatically via Smithery:

    bash
    npx -y @smithery/cli install @mahdin75/geoserver-mcp --client claude

    🛠️ Installation (Docker)

    The Docker installation is the quickest and most isolated way to run the GeoServer MCP server. It's ideal for:

    • Quick testing and evaluation
    • Production deployments
    • Environments where you want to avoid Python dependencies
    • Consistent deployment across different systems

    1. Run geoserver-mcp:

    bash
    docker pull mahdin75/geoserver-mcp
    docker run -d mahdin75/geoserver-mcp

    2. Configure the clients:

    If you are using Claude Desktop, edit claude_desktop_config.json

    If you are using Cursor, Create .cursor/mcp.json

    json
    {
      "mcpServers": {
        "geoserver-mcp": {
          "command": "docker",
          "args": [
            "run",
            "-i",
            "--rm",
            "-e",
            "GEOSERVER_URL=http://localhost:8080/geoserver",
            "-e",
            "GEOSERVER_USER=admin",
            "-e",
            "GEOSERVER_PASSWORD=geoserver",
            "-p",
            "8080:8080",
            "mahdin75/geoserver-mcp"
          ]
        }
      }
    }

    🛠️ Installation (pip)

    The pip installation is recommended for most users who want to run the server directly on their system. This method is best for:

    • Regular users who want to run the server locally
    • Systems where you have Python 3.10+ installed
    • Users who want to customize the server configuration
    • Development and testing purposes

    1. Install uv package manager.

    bash
    pip install uv

    2. Create the Virtual Environment (Python 3.10+):

    Linux/Mac:

    bash
    uv venv --python=3.10

    Windows PowerShell:

    bash
    uv venv --python=3.10

    3. Install the package using pip:

    bash
    uv pip install geoserver-mcp

    4. Configure GeoServer connection:

    Linux/Mac:

    bash
    export GEOSERVER_URL="http://localhost:8080/geoserver"
    export GEOSERVER_USER="admin"
    export GEOSERVER_PASSWORD="geoserver"

    Windows PowerShell:

    powershell
    $env:GEOSERVER_URL="http://localhost:8080/geoserver"
    $env:GEOSERVER_USER="admin"
    $env:GEOSERVER_PASSWORD="geoserver"

    5. Start the server:

    If you are going to use Claude desktop you don't need this step. For cursor or your own custom client you should run the following code.

    Linux:

    bash
    source .venv/bin/activate
    
    geoserver-mcp

    or

    bash
    source .venv/bin/activate
    
    geoserver-mcp --url http://localhost:8080/geoserver --user admin --password geoserver --debug

    Windows PowerShell:

    bash
    .\.venv\Scripts\activate
    geoserver-mcp

    or

    bash
    .\.venv\Scripts\activate
    geoserver-mcp --url http://localhost:8080/geoserver --user admin --password geoserver --debug

    6. Configure Clients:

    If you are using Claude Desktop, edit claude_desktop_config.json

    If you are using Cursor, Create .cursor/mcp.json

    Windows:

    json
    {
      "mcpServers": {
        "geoserver-mcp": {
          "command": "C:\\path\\to\\geoserver-mcp\\.venv\\Scripts\\geoserver-mcp",
          "args": [
            "--url",
            "http://localhost:8080/geoserver",
            "--user",
            "admin",
            "--password",
            "geoserver"
          ]
        }
      }
    }

    Linux:

    json
    {
      "mcpServers": {
        "geoserver-mcp": {
          "command": "/path/to/geoserver-mcp/.venv/bin/geoserver-mcp",
          "args": [
            "--url",
            "http://localhost:8080/geoserver",
            "--user",
            "admin",
            "--password",
            "geoserver"
          ]
        }
      }
    }

    🛠️ Development installation

    The development installation is designed for contributors and developers who want to modify the codebase. This method is suitable for:

    • Developers contributing to the project
    • Users who need to modify the source code
    • Testing new features
    • Debugging and development purposes

    1. Install uv package manager.

    bash
    pip install uv

    2. Create the Virtual Environment (Python 3.10+):

    bash
    uv venv --python=3.10

    3. Install the package using pip:

    bash
    uv pip install -e .

    4. Configure GeoServer connection:

    Linux/Mac:

    bash
    export GEOSERVER_URL="http://localhost:8080/geoserver"
    export GEOSERVER_USER="admin"
    export GEOSERVER_PASSWORD="geoserver"

    Windows PowerShell:

    powershell
    $env:GEOSERVER_URL="http://localhost:8080/geoserver"
    $env:GEOSERVER_USER="admin"
    $env:GEOSERVER_PASSWORD="geoserver"

    5. Start the server:

    If you are going to use Claude desktop you don't need this step. For cursor or your own custom client you should run the following code.

    Linux:

    bash
    source .venv/bin/activate
    
    geoserver-mcp

    or

    bash
    source .venv/bin/activate
    
    geoserver-mcp --url http://localhost:8080/geoserver --user admin --password geoserver --debug

    Windows PowerShell:

    bash
    .\.venv\Scripts\activate
    geoserver-mcp

    or

    bash
    .\.venv\Scripts\activate
    geoserver-mcp --url http://localhost:8080/geoserver --user admin --password geoserver --debug

    6. Configure Clients:

    If you are using Claude Desktop, edit claude_desktop_config.json

    If you are using Cursor, Create .cursor/mcp.json

    Windows:

    json
    {
      "mcpServers": {
        "geoserver-mcp": {
          "command": "C:\\path\\to\\geoserver-mcp\\.venv\\Scripts\\geoserver-mcp",
          "args": [
            "--url",
            "http://localhost:8080/geoserver",
            "--user",
            "admin",
            "--password",
            "geoserver"
          ]
        }
      }
    }

    Linux:

    json
    {
      "mcpServers": {
        "geoserver-mcp": {
          "command": "/path/to/geoserver-mcp/.venv/bin/geoserver-mcp",
          "args": [
            "--url",
            "http://localhost:8080/geoserver",
            "--user",
            "admin",
            "--password",
            "geoserver"
          ]
        }
      }
    }

    File Storage and --storage Usage

    GeoServer MCP server supports an optional --storage flag to specify a base directory for all file read/write operations, such as uploading shapefiles, GeoTIFFs, or exporting results.

    Overview

    • The --storage flag sets the root folder for file operations from all data-related tools.
    • You may supply relative paths (relative to storage root) or absolute paths (bypassing the storage root) as arguments to relevant tools.
    • If --storage is not set, paths are resolved as provided by the user (relative to working directory or absolute).

    CLI Example

    sh
    python -m geoserver_mcp.main --storage D:/my/data/dir

    This sets D:/my/data/dir as the base path for all files.

    Example tool call in Python:

    python
    # Will read from D:/my/data/dir/roads.zip if --storage is set to D:/my/data/dir
    create_shp_datastore('workspace', 'datastore_name', 'roads.zip')

    Absolute paths (e.g. 'C:/input/other.shp') are always used as-is.

    When Running in Docker

    If using Docker, ensure the storage directory is mounted as a volume, e.g.:

    sh
    docker run -v D:/my/data:/opt/data ...

    Then launch the server with:

    sh
    python -m geoserver_mcp.main --storage /opt/data

    Best Practices

    • Use relative paths when interacting with the API/tools as it keeps your setup portable.
    • For remote or container deployment, always ensure your file data is accessible within the container (use Docker volumes if needed).
    • Check tool docstrings for which arguments use the storage system.

    The --storage system streamlines file management for all users and makes deployment much more flexible!

    🛠️ Available Tools

    This section details all the available tools and resources exposed by the GeoServer MCP server. These tools allow LLMs to interact with GeoServer's REST API for comprehensive geospatial data management.

    🌍 Resource Endpoints

    Resource endpoints provide direct access to GeoServer resources via a URI pattern.

    Resource URIDescription
    geoserver://catalog/workspacesList available workspaces
    geoserver://catalog/layers/{workspace}/{layer}Get information about a specific layer
    geoserver://services/wms/{request}Handle WMS resource requests
    geoserver://services/wfs/{request}Handle WFS resource requests

    📦 Workspace Management

    ToolDescription
    list_workspacesList available workspaces in GeoServer
    create_workspaceCreate a new workspace in GeoServer

    📁 Datastore & Coveragestore Management

    ToolDescription
    create_datastoreCreate a new datastore in the given workspace
    create_featurestoreCreate a new featurestore in the given workspace
    create_gpkg_datastoreCreate a GeoPackage (GPKG) datastore
    create_shp_datastoreCreate an ESRI Shapefile datastore
    create_coveragestoreCreate a new coveragestore in a workspace
    delete_coveragestoreDelete a coveragestore from a workspace
    get_coveragestoreGet details about a single coveragestore
    get_coveragestoresGet all coveragestores for a workspace
    get_datastoreGet a specific datastore by name
    get_datastoresList all datastores in the given workspace

    🗺️ Layer Management

    ToolDescription
    get_layer_infoGet detailed information about a layer
    list_layersList layers in GeoServer, optionally filtered by workspace
    create_layerCreate a new layer in GeoServer
    delete_resourceDelete a resource from GeoServer (generic)

    🧩 Layer Group Management

    ToolDescription
    create_layergroupCreate a new layer group with specific layers and (optionally) styles
    get_layergroupGet a layer group from a workspace
    get_layergroupsList all layer groups in a workspace
    add_layer_to_layergroupAdd a specific layer to a layer group
    remove_layer_from_layergroupRemove a layer from a group
    delete_layergroupDelete a layer group from a workspace
    update_layergroupUpdate a layer group's details and configuration

    👥 User & User Group Management

    ToolDescription
    create_userCreate a new user for GeoServer security
    delete_userDelete a user by name
    get_all_usersList all users in the GeoServer instance
    modify_userModify an existing user's properties
    create_usergroupCreate a new user group
    delete_usergroupDelete a user group
    get_all_usergroupsReturn all user groups

    📊 Feature Type & Attribute Management

    ToolDescription
    query_featuresQuery features from a vector layer using CQL filter
    publish_featurestorePublish an existing featurestore
    publish_featurestore_sqlviewPublish a featurestore using a SQL view definition
    edit_featuretypeEdit the settings of a feature type in a store
    get_featuretypesList all feature types in a given store
    get_feature_attributeGet feature attribute schema/details

    🎨 Style Management

    ToolDescription
    create_styleCreate a new SLD style in GeoServer
    publish_styleAssign/publish a style to a layer
    create_catagorized_featurestyleCreate a categorized style for features
    create_classified_featurestyleCreate a classified style for features
    create_coveragestyleCreate a raster coverage style
    create_outline_featurestyleCreate a simple outline-only style for features

    ⚙️ System & Service Operations

    ToolDescription
    get_manifestGet GeoServer manifest metadata/details
    get_statusObtain general server status
    get_system_statusGet system status overview/info from GeoServer
    get_versionFetch GeoServer version string
    reload_geoserverReload catalog and config from disk
    reset_geoserverReset all GeoServer caches/connections
    update_serviceUpdate selected OGC service options
    publish_time_dimension_to_coveragestoreAdd or update a time dimension for a coverage store (for time series)

    📝 Style XML Utilities

    ToolDescription
    style_catagorize_xmlGenerate SLD for categorized vector style
    style_classified_xmlGet SLD XML for classified vector style
    style_coverage_style_colormapentryGenerate color map entries for raster SLD
    style_coverage_style_xmlGenerate XML for raster/coverage SLD
    style_outline_only_xmlXML for outline-only style for a geometry

    🛠️ Client Development

    If you're planning to develop your own client to interact with the GeoServer MCP server, you can find inspiration in the example client implementation at examples/client.py. This example demonstrates:

    • How to establish a connection with the MCP server
    • How to send requests and handle responses
    • Basic error handling and connection management
    • Example usage of various tools and operations

    The example client serves as a good starting point for understanding the protocol and implementing your own client applications.

    Also, here is the example usgage:

    List Workspaces

    code
    Tool: list_workspaces
    Parameters: {}
    Response: ["default", "demo", "topp", "tiger", "sf"]

    Get Layer Information

    code
    Tool: get_layer_info
    Parameters: {
    "workspace": "topp",
    "layer": "states"
    }

    Query Features

    code
    Tool: query_features
    Parameters: {
    "workspace": "topp",
    "layer": "states",
    "filter": "PERSONS > 10000000",
    "properties": ["STATE_NAME", "PERSONS"]
    }

    Generate Map

    code
    Tool: generate_map
    Parameters: {
    "layers": ["topp:states"],
    "styles": ["population"],
    "bbox": [-124.73, 24.96, -66.97, 49.37],
    "width": 800,
    "height": 600,
    "format": "png"
    }

    🔮 Planned Features

    • [ ] Coverage and raster data management
    • [ ] Security and access control
    • [ ] Advanced styling capabilities
    • [ ] WPS processing operations
    • [ ] GeoWebCache integration

    🤝 Contributing

    We welcome contributions! Here's how you can help:

    1. Fork the repository

    2. Create a feature branch (git checkout -b feature/AmazingFeature)

    3. Commit your changes (git commit -m 'Add some AmazingFeature')

    4. Push to the branch (git push origin feature/AmazingFeature)

    5. Open a Pull Request

    Please ensure your PR description clearly describes the problem and solution. Include the relevant issue number if applicable.

    📄 License

    This project is licensed under the MIT License - see the LICENSE file for details.

    🔗 Related Projects

    • Model Context Protocol - The core MCP implementation
    • GeoServer REST API - Official GeoServer REST documentation
    • GeoServer REST Python Client - Python client for GeoServer REST API

    🌐 See Also: GIS MCP

    For broader geospatial data automation and even more GIS-related MCP features, see GIS MCP by mahdin75.

    📞 Support

    For support, please Open an issue

    🏆 Badges

    Similar MCP

    Based on tags & features

    • MA

      Mayamcp

      Python·
      27
    • BI

      Biothings Mcp

      Python·
      25
    • FH

      Fhir Mcp Server

      Python·
      55
    • MC

      Mcp Aoai Web Browsing

      Python·
      30

    Trending MCP

    Most active this week

    • PL

      Playwright Mcp

      TypeScript·
      22.1k
    • SE

      Serena

      Python·
      14.5k
    • MC

      Mcp Playwright

      TypeScript·
      4.9k
    • MC

      Mcp Server Cloudflare

      TypeScript·
      3.0k
    View All MCP Servers

    Similar MCP

    Based on tags & features

    • MA

      Mayamcp

      Python·
      27
    • BI

      Biothings Mcp

      Python·
      25
    • FH

      Fhir Mcp Server

      Python·
      55
    • MC

      Mcp Aoai Web Browsing

      Python·
      30

    Trending MCP

    Most active this week

    • PL

      Playwright Mcp

      TypeScript·
      22.1k
    • SE

      Serena

      Python·
      14.5k
    • MC

      Mcp Playwright

      TypeScript·
      4.9k
    • MC

      Mcp Server Cloudflare

      TypeScript·
      3.0k