Azure Data Explorer MCP Server

Azure Data Explorer MCP Server

Enables AI assistants to query and analyze Azure Data Explorer using the Model Context Protocol.

49
Stars
23
Forks
49
Watchers
0
Issues
Azure Data Explorer MCP Server provides standardized MCP interfaces for AI assistants to execute KQL queries and interact with Azure Data Explorer (ADX/Kusto) databases. It supports secure authentication methods, database discovery, and delivers structured results in JSON format. Multiple deployment options, including Docker and various transports, enable flexible integration into development or production environments.

Key Features

Execute arbitrary KQL queries against ADX databases
Structured JSON results for easy consumption
Database schema discovery and table listing
Sample data retrieval with configurable sample sizes
Detailed table metadata including statistics
Multiple authentication methods (DefaultAzureCredential, Workload Identity)
Transport flexibility (stdio, HTTP, SSE)
Production-ready Docker container support
Configurable tool list for client integration
Development support via Dev Containers and GitHub Codespaces

Use Cases

Empowering AI assistants to analyze Azure Data Explorer data
Automating KQL query execution from AI-driven platforms
Providing programmatic access to ADX schemas and metadata
Building developer tools for interactive ADX database exploration
Integrating with cloud-native authentication flows in enterprise environments
Deploying MCP-compatible data query backends in production using Docker
Developing analytics solutions that require standardized context protocols
Rapid prototyping of AI model connections to Azure data sources
Enhancing data engineering workflows through customizable toolsets
Supporting secure and flexible data access in multi-tenant cloud environments

README

Azure Data Explorer MCP Server

CI codecov License: MIT Python 3.12

A Model Context Protocol (MCP) server that enables AI assistants to execute KQL queries and explore Azure Data Explorer (ADX/Kusto) databases through standardized interfaces.

This server provides seamless access to Azure Data Explorer and Eventhouse (in Microsoft Fabric) clusters, allowing AI assistants to query and analyze your data using the powerful Kusto Query Language.

Features

Query Execution

  • Execute KQL queries - Run arbitrary KQL queries against your ADX database
  • Structured results - Get results formatted as JSON for easy consumption

Database Discovery

  • List tables - Discover all tables in your database
  • View schemas - Inspect table schemas and column types
  • Sample data - Preview table contents with configurable sample sizes
  • Table statistics - Get detailed metadata including row counts and storage size

Authentication

  • DefaultAzureCredential - Supports Azure CLI, Managed Identity, and more
  • Workload Identity - Native support for AKS workload identity
  • Flexible credentials - Works with multiple Azure authentication methods

Deployment Options

  • Multiple transports - stdio (default), HTTP, and Server-Sent Events (SSE)
  • Docker support - Production-ready container images with security best practices
  • Dev Container - Seamless development experience with GitHub Codespaces

The list of tools is configurable, so you can choose which tools you want to make available to the MCP client. This is useful if you don't use certain functionality or if you don't want to take up too much of the context window.

Usage

  1. Login to your Azure account which has the permission to the ADX cluster using Azure CLI.

  2. Configure the environment variables for your ADX cluster, either through a .env file or system environment variables:

env
# Required: Azure Data Explorer configuration
ADX_CLUSTER_URL=https://yourcluster.region.kusto.windows.net
ADX_DATABASE=your_database

# Optional: Azure Workload Identity credentials 
# AZURE_TENANT_ID=your-tenant-id
# AZURE_CLIENT_ID=your-client-id 
# ADX_TOKEN_FILE_PATH=/var/run/secrets/azure/tokens/azure-identity-token

# Optional: Custom MCP Server configuration
ADX_MCP_SERVER_TRANSPORT=stdio # Choose between http/sse/stdio, default = stdio

# Optional: Only relevant for non-stdio transports
ADX_MCP_BIND_HOST=127.0.0.1 # default = 127.0.0.1
ADX_MCP_BIND_PORT=8080 # default = 8080

Azure Workload Identity Support

The server now uses WorkloadIdentityCredential by default when running in Azure Kubernetes Service (AKS) environments with workload identity configured. It prioritizes the use of WorkloadIdentityCredential whenever the necessary environment variables are present.

For AKS with Azure Workload Identity, you only need to:

  1. Make sure the pod has AZURE_TENANT_ID and AZURE_CLIENT_ID environment variables set
  2. Ensure the token file is mounted at the default path or specify a custom path with ADX_TOKEN_FILE_PATH

If these environment variables are not present, the server will automatically fall back to DefaultAzureCredential, which tries multiple authentication methods in sequence.

  1. Add the server configuration to your client configuration file. For example, for Claude Desktop:
json
{
  "mcpServers": {
    "adx": {
      "command": "uv",
      "args": [
        "--directory",
        "<full path to adx-mcp-server directory>",
        "run",
        "src/adx_mcp_server/main.py"
      ],
      "env": {
        "ADX_CLUSTER_URL": "https://yourcluster.region.kusto.windows.net",
        "ADX_DATABASE": "your_database"
      }
    }
  }
}

Note: if you see Error: spawn uv ENOENT in Claude Desktop, you may need to specify the full path to uv or set the environment variable NO_UV=1 in the configuration.

Docker Usage

This project includes Docker support for easy deployment and isolation.

Building the Docker Image

Build the Docker image using:

bash
docker build -t adx-mcp-server .

Running with Docker

You can run the server using Docker in several ways:

Using docker run directly:

bash
docker run -it --rm \
  -e ADX_CLUSTER_URL=https://yourcluster.region.kusto.windows.net \
  -e ADX_DATABASE=your_database \
  -e AZURE_TENANT_ID=your_tenant_id \
  -e AZURE_CLIENT_ID=your_client_id \
  adx-mcp-server

Using docker-compose:

Create a .env file with your Azure Data Explorer credentials and then run:

bash
docker-compose up

Running with Docker in Claude Desktop

To use the containerized server with Claude Desktop, update the configuration to use Docker with the environment variables:

json
{
  "mcpServers": {
    "adx": {
      "command": "docker",
      "args": [
        "run",
        "--rm",
        "-i",
        "-e", "ADX_CLUSTER_URL",
        "-e", "ADX_DATABASE",
        "-e", "AZURE_TENANT_ID",
        "-e", "AZURE_CLIENT_ID",
        "-e", "ADX_TOKEN_FILE_PATH",
        "adx-mcp-server"
      ],
      "env": {
        "ADX_CLUSTER_URL": "https://yourcluster.region.kusto.windows.net",
        "ADX_DATABASE": "your_database",
        "AZURE_TENANT_ID": "your_tenant_id",
        "AZURE_CLIENT_ID": "your_client_id",
        "ADX_TOKEN_FILE_PATH": "/var/run/secrets/azure/tokens/azure-identity-token"
      }
    }
  }
}

This configuration passes the environment variables from Claude Desktop to the Docker container by using the -e flag with just the variable name, and providing the actual values in the env object.

Using Docker with HTTP Transport

For HTTP mode deployment, you can use the following Docker configuration:

json
{
  "mcpServers": {
    "adx": {
      "command": "docker",
      "args": [
        "run",
        "--rm",
        "-i",
        "-p", "8080:8080",
        "-e", "ADX_CLUSTER_URL",
        "-e", "ADX_DATABASE", 
        "-e", "ADX_MCP_SERVER_TRANSPORT",
        "-e", "ADX_MCP_BIND_HOST",
        "-e", "ADX_MCP_BIND_PORT",
        "adx-mcp-server"
      ],
      "env": {
        "ADX_CLUSTER_URL": "https://yourcluster.region.kusto.windows.net",
        "ADX_DATABASE": "your_database",
        "ADX_MCP_SERVER_TRANSPORT": "http",
        "ADX_MCP_BIND_HOST": "0.0.0.0",
        "ADX_MCP_BIND_PORT": "8080"
      }
    }
  }
}

Using as a Dev Container / GitHub Codespace

This repository can also be used as a development container for a seamless development experience. The dev container setup is located in the devcontainer-feature/adx-mcp-server folder.

For more details, check the devcontainer README.

Development

Contributions are welcome! Please open an issue or submit a pull request if you have any suggestions or improvements.

This project uses uv to manage dependencies. Install uv following the instructions for your platform:

bash
curl -LsSf https://astral.sh/uv/install.sh | sh

You can then create a virtual environment and install the dependencies with:

bash
uv venv
source .venv/bin/activate  # On Unix/macOS
.venv\Scripts\activate     # On Windows
uv pip install -e .

Project Structure

The project has been organized with a src directory structure:

adx-mcp-server/
├── src/
│   └── adx_mcp_server/
│       ├── __init__.py      # Package initialization
│       ├── server.py        # MCP server implementation
│       ├── main.py          # Main application logic
├── Dockerfile               # Docker configuration
├── docker-compose.yml       # Docker Compose configuration
├── .dockerignore            # Docker ignore file
├── pyproject.toml           # Project configuration
└── README.md                # This file

Testing

The project includes a comprehensive test suite that ensures functionality and helps prevent regressions.

Run the tests with pytest:

bash
# Install development dependencies
uv pip install -e ".[dev]"

# Run the tests
pytest

# Run with coverage report
pytest --cov=src --cov-report=term-missing

Tests are organized into:

  • Configuration validation tests
  • Server functionality tests
  • Error handling tests
  • Main application tests

When adding new features, please also add corresponding tests.

Available Tools

Tool Category Description Parameters
execute_query Query Execute a KQL query against Azure Data Explorer query (string) - KQL query to execute
list_tables Discovery List all tables in the configured database None
get_table_schema Discovery Get the schema for a specific table table_name (string) - Name of the table
sample_table_data Discovery Get sample data from a table table_name (string), sample_size (int, default: 10)
get_table_details Discovery Get table statistics and metadata table_name (string) - Name of the table

Configuration

Required Environment Variables

Variable Description Example
ADX_CLUSTER_URL Azure Data Explorer cluster URL https://yourcluster.region.kusto.windows.net
ADX_DATABASE Database name to connect to your_database

Optional Environment Variables

Azure Workload Identity (for AKS)

Variable Description Default
AZURE_TENANT_ID Azure AD tenant ID -
AZURE_CLIENT_ID Azure AD client/application ID -
ADX_TOKEN_FILE_PATH Path to workload identity token file /var/run/secrets/azure/tokens/azure-identity-token

MCP Server Configuration

Variable Description Default
ADX_MCP_SERVER_TRANSPORT Transport mode: stdio, http, or sse stdio
ADX_MCP_BIND_HOST Host to bind to (HTTP/SSE only) 127.0.0.1
ADX_MCP_BIND_PORT Port to bind to (HTTP/SSE only) 8080

Logging

Variable Description Default
LOG_LEVEL Logging level: DEBUG, INFO, WARNING, ERROR INFO

License

MIT


Star History

Star History Chart

Repository Owner

pab1it0
pab1it0

User

Repository Details

Language Python
Default Branch main
Size 188 KB
Contributors 5
License MIT License
MCP Verified Nov 12, 2025

Programming Languages

Python
93.6%
Dockerfile
4.31%
Shell
2.1%

Tags

Join Our Newsletter

Stay updated with the latest AI tools, news, and offers by subscribing to our weekly newsletter.

We respect your privacy. Unsubscribe at any time.

Related MCPs

Discover similar Model Context Protocol servers

  • Prometheus MCP Server

    Prometheus MCP Server

    Access and analyze Prometheus metrics through standardized MCP interfaces.

    Prometheus MCP Server enables seamless access to Prometheus metrics by providing a standardized Model Context Protocol (MCP) interface. It allows AI assistants and compatible clients to execute PromQL queries, discover and explore metric data, and retrieve instant or range-based results. The server supports authentication via basic and bearer token mechanisms and can be easily deployed via Docker or integrated into multiple development environments.

    • 282
    • MCP
    • pab1it0/prometheus-mcp-server
  • Azure DevOps MCP Server

    Azure DevOps MCP Server

    Standardized AI access to Azure DevOps via Model Context Protocol.

    Implements the Model Context Protocol (MCP) to enable AI assistants to securely and efficiently interact with Azure DevOps resources. Provides a standardized bridge for managing projects, work items, repositories, pull requests, and pipelines through natural language interfaces. Supports modular authentication and a feature-based architecture for scalability and integration. Facilitates seamless integration with AI tools such as Claude Desktop and Cursor AI.

    • 306
    • MCP
    • Tiberriver256/mcp-server-azure-devops
  • Azure MCP Server

    Azure MCP Server

    Connect AI agents with Azure services through Model Context Protocol.

    Azure MCP Server provides a seamless interface between AI agents and Azure services by implementing the Model Context Protocol (MCP) specification. It enables integration with tools like GitHub Copilot for Azure and supports a wide range of Azure resource management tasks directly via conversational AI interfaces. Designed for extensibility and compatibility, it offers enhanced contextual capabilities for agents working with Azure environments.

    • 1,178
    • MCP
    • Azure/azure-mcp
  • Multi-Database MCP Server (by Legion AI)

    Multi-Database MCP Server (by Legion AI)

    Unified multi-database access and AI interaction server with MCP integration.

    Multi-Database MCP Server enables seamless access and querying of diverse databases via a unified API, with native support for the Model Context Protocol (MCP). It supports popular databases such as PostgreSQL, MySQL, SQL Server, and more, and is built for integration with AI assistants and agents. Leveraging the MCP Python SDK, it exposes databases as resources, tools, and prompts for intelligent, context-aware interactions, while delivering zero-configuration schema discovery and secure credential management.

    • 76
    • MCP
    • TheRaLabs/legion-mcp
  • Alkemi MCP Server

    Alkemi MCP Server

    Integrate Alkemi Data sources with MCP Clients for seamless, standardized data querying.

    Alkemi MCP Server provides a STDIO wrapper for connecting Alkemi data sources—including Snowflake, Google BigQuery, and Databricks—with MCP Clients using the Model Context Protocol. It facilitates context sharing, database metadata management, and query generation through a standardized protocol endpoint. Shared MCP Servers allow teams to maintain consistent, high-quality data querying capabilities without needing to replicate schemas or query knowledge for each agent. Out-of-the-box integration with Claude Desktop and robust debugging tools are also included.

    • 2
    • MCP
    • alkemi-ai/alkemi-mcp
  • ROADrecon MCP Server

    ROADrecon MCP Server

    Expose ROADRecon Azure AD data to AI assistants for advanced security analysis.

    ROADrecon MCP Server implements the Model Context Protocol to provide seamless access to Azure AD data from ROADRecon instances for AI assistants like Claude. It enables secure retrieval and analysis of directory data, offers pre-built security analysis tools, and supplies prompt templates for common security tasks. The server facilitates structured data access and tool execution, streamlining organizational security reviews.

    • 47
    • MCP
    • atomicchonk/roadrecon_mcp_server
  • Didn't find tool you were looking for?

    Be as detailed as possible for better results