小贴士:按下Ctrl+D 或 ⌘+D,一键收藏本站,方便下次快速访问!
MIT License
13
最近更新:2个月前

一种模型上下文协议 (MCP) 的实现,使 Claude Desktop 能够与 Azure 服务进行交互。通过此集成,Claude 可以通过自然语言对话直接查询和管理 Azure 资源。

Azure MCP(模型上下文协议)for Claude Desktop

smithery badge

一种模型上下文协议(MCP)的实现,使 Claude Desktop 能够与 Azure 服务交互。此集成允许 Claude 通过自然语言对话直接查询和管理 Azure 资源。

特性

  • Azure 资源管理:与 Azure 资源管理客户端交互
  • 订阅管理:列出和管理 Azure 订阅
  • 租户管理:列出和选择 Azure 租户
  • 自动身份验证:利用 DefaultAzureCredential 提供灵活的身份验证方法
  • 错误处理:针对临时故障提供重试机制的强大错误处理
  • 清晰的响应格式:兼容 Claude Desktop 的正确格式化响应

先决条件

  • Node.js(v18 或更高版本)
  • Claude Desktop 应用程序
  • 具有适当权限的 Azure 账户
  • Azure CLI(可选,用于基于 CLI 的身份验证)

安装

手动安装

  1. 克隆存储库:
bash 复制代码
git clone https://github.com/Streen9/azure-mcp.git
cd azure-mcp
  1. 安装依赖:
bash 复制代码
npm install
  1. 配置 Claude Desktop:
    • 打开 claude_desktop_config.json
    • 添加以下 MCP 配置:
json 复制代码
{
  "mcpServers": {
    "sequential-thinking": {
      "command": "npx",
      "args": [
        "-y",
        "@modelcontextprotocol/server-sequential-thinking"
      ]
    },
    "azure": {
      "command": "tsx",
      "args": [
        "C:/Users/[YourUsername]/path/to/azure-mcp/src/launcher.ts"
      ]
    }
  }
}

身份验证

服务器通过 DefaultAzureCredential 支持多种身份验证方法:

  • 环境变量
  • 托管身份
  • Azure CLI
  • Visual Studio Code
  • 交互式浏览器

服务器将自动按顺序尝试这些方法,直到其中一个成功。

使用

  1. 如果 Claude Desktop 正在运行,请关闭它(检查任务管理器)
  2. 启动 Claude Desktop
  3. 在聊天中,你现在可以询问与 Azure 相关的问题,例如:
    • “你能获取所有可用的 Azure 账户和订阅吗?”
    • “列出我订阅中的所有资源组”
    • “显示特定资源组中的所有虚拟机”

示例对话

复制代码
你:你能获取所有可用的 Azure 账户和订阅吗?
Claude:我将帮助你列出所有可用的 Azure 租户和订阅。
[Claude 将使用 Azure MCP 获取并显示信息]

开发

项目结构

复制代码
azure-mcp/
├── src/
│   ├── launcher.ts       # 服务器入口点
│   ├── AzureServer.ts    # 主要的 MCP 服务器实现
│   └── LoggerService.ts  # 日志工具
├── package.json
└── README.md

关键组件

  • AzureMCPServer:实现 MCP 协议的主要服务器类
  • HandleCallTool:处理传入的工具请求
  • ExecuteWithRetry:为弹性操作实现重试逻辑

故障排除

  1. 身份验证问题

    • 确保通过 Azure CLI 登录 (az login)
    • 如果使用服务主体,请检查环境变量
    • 验证你的 Azure 账户是否具有必要权限
  2. 连接问题

    • 验证 Claude Desktop 配置
    • 检查配置文件中的路径是否匹配你的安装
    • 确保没有其他实例正在运行
  3. 常见错误

    • NO_TENANT:使用 'select-tenant' 工具选择租户
    • NO_CLIENTS:确保正确的初始化和身份验证
    • CODE_EXECUTION_FAILED:检查 Azure 权限和连接

贡献

欢迎贡献!请随时提交拉取请求。

贡献者

致谢

  • Claude Desktop 团队实现了 MCP
  • Azure SDK 团队提供了全面的 SDK
  • Model Context Protocol 实现了 AI 服务集成

安全说明

该实现遵循 Azure 安全最佳实践:

  • 没有硬编码凭据
  • 安全的凭据链实现
  • 正确的错误处理和清理

如有安全问题或漏洞,请创建一个问题。