Azure Data Explorer MCP Server

Azure Data Explorer MCP Server

镜子 (jìng zi)

MCP-Mirror

研究与数据
访问服务器

README

Azure Data Explorer MCP 服务器

<a href="https://glama.ai/mcp/servers/1yysyd147h"> <img width="380" height="200" src="https://glama.ai/mcp/servers/1yysyd147h/badge" /> </a>

一个用于 Azure Data Explorer 的 模型上下文协议 (MCP) 服务器。

它通过标准化的 MCP 接口提供对 Azure Data Explorer 集群和数据库的访问,允许 AI 助手执行 KQL 查询并探索您的数据。

功能

  • [x] 执行针对 Azure Data Explorer 的 KQL 查询

  • [x] 发现和探索数据库资源

    • [x] 列出配置数据库中的表
    • [x] 查看表结构
    • [x] 从表中抽样数据
  • [x] 身份验证支持

    • [x] 令牌凭据支持 (Azure CLI, MSI, 等)
  • [x] Docker 容器化支持

  • [x] 为 AI 助手提供交互式工具

工具列表是可配置的,因此您可以选择要提供给 MCP 客户端的工具。 如果您不使用某些功能,或者不想占用太多的上下文窗口,这将非常有用。

用法

  1. 使用 Azure CLI 登录到您的 Azure 帐户,该帐户具有对 ADX 集群的权限。

  2. 配置 ADX 集群的环境变量,可以通过 .env 文件或系统环境变量:

# 必需:Azure Data Explorer 配置
ADX_CLUSTER_URL=https://yourcluster.region.kusto.windows.net
ADX_DATABASE=your_database
  1. 将服务器配置添加到您的客户端配置文件。 例如,对于 Claude Desktop:
{
  "mcpServers": {
    "adx": {
      "command": "uv",
      "args": [
        "--directory",
        "<adx-mcp-server 目录的完整路径>",
        "run",
        "src/adx_mcp_server/main.py"
      ],
      "env": {
        "ADX_CLUSTER_URL": "https://yourcluster.region.kusto.windows.net",
        "ADX_DATABASE": "your_database"
      }
    }
  }
}

注意:如果在 Claude Desktop 中看到 Error: spawn uv ENOENT,您可能需要指定 uv 的完整路径,或者在配置中设置环境变量 NO_UV=1

Docker 用法

该项目包含 Docker 支持,以便于部署和隔离。

构建 Docker 镜像

使用以下命令构建 Docker 镜像:

docker build -t adx-mcp-server .

使用 Docker 运行

您可以通过多种方式使用 Docker 运行服务器:

直接使用 docker run:

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

使用 docker-compose:

创建一个包含 Azure Data Explorer 凭据的 .env 文件,然后运行:

docker-compose up

在 Claude Desktop 中使用 Docker 运行

要将容器化服务器与 Claude Desktop 一起使用,请更新配置以使用 Docker 和环境变量:

{
  "mcpServers": {
    "adx": {
      "command": "docker",
      "args": [
        "run",
        "--rm",
        "-i",
        "-e", "ADX_CLUSTER_URL",
        "-e", "ADX_DATABASE",
        "adx-mcp-server"
      ],
      "env": {
        "ADX_CLUSTER_URL": "https://yourcluster.region.kusto.windows.net",
        "ADX_DATABASE": "your_database"
      }
    }
  }
}

此配置通过使用 -e 标志(仅使用变量名)将环境变量从 Claude Desktop 传递到 Docker 容器,并在 env 对象中提供实际值。

开发

欢迎贡献! 如果您有任何建议或改进,请打开一个 issue 或提交一个 pull request。

该项目使用 uv 来管理依赖项。 按照适用于您平台的说明安装 uv

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

然后,您可以创建一个虚拟环境并使用以下命令安装依赖项:

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

项目结构

该项目已组织成一个 src 目录结构:

adx-mcp-server/
├── src/
│   └── adx_mcp_server/
│       ├── __init__.py      # 包初始化
│       ├── server.py        # MCP 服务器实现
│       ├── main.py          # 主要应用程序逻辑
├── Dockerfile               # Docker 配置
├── docker-compose.yml       # Docker Compose 配置
├── .dockerignore            # Docker 忽略文件
├── pyproject.toml           # 项目配置
└── README.md                # 此文件

测试

该项目包含一个全面的测试套件,可确保功能并有助于防止回归。

使用 pytest 运行测试:

# 安装开发依赖项
uv pip install -e ".[dev]"

# 运行测试
pytest

# 运行并生成覆盖率报告
pytest --cov=src --cov-report=term-missing

测试组织成:

  • 配置验证测试
  • 服务器功能测试
  • 错误处理测试
  • 主要应用程序测试

添加新功能时,请同时添加相应的测试。

工具

工具 类别 描述
execute_query 查询 执行针对 Azure Data Explorer 的 KQL 查询
list_tables 发现 列出配置数据库中的所有表
get_table_schema 发现 获取特定表的结构
sample_table_data 发现 从表中获取样本数据,并可选择样本大小

许可证

MIT


推荐服务器

Crypto Price & Market Analysis MCP Server

Crypto Price & Market Analysis MCP Server

一个模型上下文协议 (MCP) 服务器,它使用 CoinCap API 提供全面的加密货币分析。该服务器通过一个易于使用的界面提供实时价格数据、市场分析和历史趋势。 (Alternative, slightly more formal and technical translation): 一个模型上下文协议 (MCP) 服务器,利用 CoinCap API 提供全面的加密货币分析服务。该服务器通过用户友好的界面,提供实时价格数据、市场分析以及历史趋势数据。

精选
TypeScript
MCP PubMed Search

MCP PubMed Search

用于搜索 PubMed 的服务器(PubMed 是一个免费的在线数据库,用户可以在其中搜索生物医学和生命科学文献)。 我是在 MCP 发布当天创建的,但当时正在度假。 我看到有人在您的数据库中发布了类似的服务器,但还是决定发布我的服务器。

精选
Python
mixpanel

mixpanel

连接到您的 Mixpanel 数据。 从 Mixpanel 分析查询事件、留存和漏斗数据。

精选
TypeScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

这个服务器通过将复杂问题分解为顺序步骤来促进结构化的问题解决,支持修订,并通过完整的 MCP 集成来实现多条解决方案路径。

精选
Python
Nefino MCP Server

Nefino MCP Server

为大型语言模型提供访问德国可再生能源项目新闻和信息的能力,允许按地点、主题(太阳能、风能、氢能)和日期范围进行筛选。

官方
Python
Vectorize

Vectorize

将 MCP 服务器向量化以实现高级检索、私有深度研究、Anything-to-Markdown 文件提取和文本分块。

官方
JavaScript
Mathematica Documentation MCP server

Mathematica Documentation MCP server

一个服务器,通过 FastMCP 提供对 Mathematica 文档的访问,使用户能够从 Wolfram Mathematica 检索函数文档和列出软件包符号。

本地
Python
kb-mcp-server

kb-mcp-server

一个 MCP 服务器,旨在实现便携性、本地化、简易性和便利性,以支持对 txtai “all in one” 嵌入数据库进行基于语义/图的检索。任何 tar.gz 格式的 txtai 嵌入数据库都可以被加载。

本地
Python
Research MCP Server

Research MCP Server

这个服务器用作 MCP 服务器,与 Notion 交互以检索和创建调查数据,并与 Claude Desktop Client 集成以进行和审查调查。

本地
Python
Cryo MCP Server

Cryo MCP Server

一个API服务器,实现了模型补全协议(MCP),用于Cryo区块链数据提取,允许用户通过任何兼容MCP的客户端查询以太坊区块链数据。

本地
Python