10行代码,快速搭建你的专属阿里云OpenAPI MCP Server

仅需10行Python代码,快速搭建专属阿里云OpenAPI MCP Server!告别繁琐配置,轻松拓展AI能力。

原文标题:10行代码,实现你的OpenAPI MCP Server

原文作者:阿里云开发者

冷月清谈:

本文介绍了如何使用不到10行Python代码,借助alibaba-cloud-ops-mcp-server快速构建一个专属的阿里云OpenAPI MCP Server。 传统MCP Server存在工具固化、Token消耗高、二次开发复杂等问题,而本文方案通过OpenAPI元数据自动生成Tools,无需手动编写,简化了开发流程。 主要步骤包括:
1. 配置需要的阿里云服务和API名称。
2. 运行给定的Python代码,自动生成MCP Server。
3. 配置MCP Client(如Cherry-Studio、Cline),连接到MCP Server。

该方案具有无需重复编写Tools、无需深入了解OpenAPI实现细节、极大降低开发门槛等优点。 未来,该方案有望拓展到其他具有标准格式元数据的API,并探索通用API调用方案,实现更智能的API检索和调用。

怜星夜思:

1、文章中提到,目前的方案是一个API对应一个工具,未来会尝试设计通用方案,你觉得在实际应用中,通用API调用方案会面临哪些挑战?
2、文章中提到了可以扩展到其他具有标准格式元数据的API,你觉得除了阿里云OpenAPI,还有哪些场景可以使用这种方案?
3、文章里说只需修改config文件就能调整支持的Tools,但如果我想增加一些额外的逻辑,比如在调用API前后做一些数据处理,应该怎么做?

原文内容

一、引言:MCP Server新范式

在Model Context Protocol (MCP)爆火的今天,MCP Server的局限性日益凸显:MCP市场提供的MCP Server往往只能提供有限的能力,不够灵活,无法根据用户的具体需求灵活拓展或调整,过多的工具又会导致Token的大量消耗。

而作为阿里云的用户,阿里云OpenAPI便是我们和资源之间的桥梁与通道,通常我们会希望通过OpenAPI来实现各种复杂需求,而每个OpenAPI往往就对应MCP Server的一个具体的Tools,但是阿里云拥有海量的OpenAPI,单纯的穷举,将每个OpenAPI都注册为Tools显然是不适合MCP Server的模式,本文将分享如何借助alibaba-cloud-ops-mcp-server[1]实现仅靠10行python代码即可创建你的专属阿里云OpenAPI MCP Server。

通过本文的实践,你将掌握如何在极少的代码量内,构建一个功能丰富的MCP Server,希望本文所提方案能够为MCP Server的开发提供新的思路和方法。

二、核心原理

在动手实现之前,我们需要理解几个MCP Server的关键概念和整体运行逻辑。掌握这些核心机制,将帮助你深入理解MCP Server背后的运作流程,并在实际开发中更加灵活地构建自己的专属MCP Server。

MCP Server的实现原理

Model Context Protocol (MCP) 是一个开放协议,旨在实现 LLM 应用与外部数据源和工具之间的无缝集成。无论你是构建 AI 驱动的 IDE、增强聊天界面,还是创建自定义 AI 工作流,MCP 都提供了一种标准化的方式来连接 LLM 与外部世界。

简单来说,MCP 是一种客户端-服务器架构的协议,允许 LLM 应用程序(如 Claude、各种 IDE 等)通过标准化的接口访问外部数据和功能。这解决了 LLM 在实际应用中常见的一些痛点:

  • LLM 无法直接访问实时数据(如天气、股票行情等)
  • LLM 无法执行外部操作(如发送邮件、控制设备等)
  • LLM 无法访问用户的本地文件或其他私有数据

通过 MCP,这些限制得到了优雅的解决,同时保持了安全性和可扩展性。

  • MCP 主机:像 Claude Desktop、IDE 或 AI 工具这样的程序,需要通过 MCP 访问数据
  • MCP 客户端:与服务器保持 1:1 连接的协议客户端
  • MCP 服务器:轻量级程序,每个程序都通过标准化模型上下文协议公开特定功能
  • 本地数据源:MCP 服务器可以安全的访问计算机上的文件、数据库和服务
  • 远程服务:MCP 服务器可以通过互联网(例如通过 API)连接到的外部系统

MCP Server 关键概念

MCP 服务器可以提供三种主要类型的功能:

  • 资源Resource,客户端可以读取的类似文件的数据(例如 API 响应或文件内容)
  • 工具Tool,可由 LLM 调用的函数(经用户批准)
  • 提示Prompt,预先编写的模板,帮助用户完成特定任务

但是当前的MCP Server主要聚焦于提供各种不同功能的工具,用户可以通过编写工具来提供AI更多与现实交互的能力。

工具即为函数,定义一个工具通常需要包含以下必须的属性:

  • 函数描述:函数本身具备的具体功能及使用场景
  • 函数参数:调用该函数所需的参数定义(参数的类型、描述及是否必填等信息)

阿里云OpenAPI元数据

阿里云OpenAPI 开放元数据,是OpenAPI 的描述规范。 OpenAPI 开放元数据,在参照 OAS2 [2] JSONSchema [3]标准的同时,也由于阿里云 OpenAPI 自身的特点做了局部的调整。OpenAPI 规范本身可以被视为 API 元数据的一种表现形式。它提供了 API 的技术细节(如端点、参数、响应格式),同时也包含了一些基本信息(如标题、版本、描述)。

通过上文的讲解,可以看出,OpenAPI 元数据中包含了MCP Server工具的必需属性。在编写工具时,我们完全可以借助OpenAPI 元数据来实现对于工具的定义。

当前MCP Server存在的痛点

  • MCP Server提供的工具固化,不够灵活
  • 若为大而全,工具数量提升导致的Token消耗
  • 用户若根据需求进行二次开发,编写工具繁琐复杂,且用户需要深入了解阿里云Open API

alibaba-cloud-ops-mcp-server的具体实现


三、动手实践:创造一个专属的

自定义阿里云OpenAPI MCP Server

配置编辑

首先,可以将需要的服务名称及API名称记录在config中,以便后续程序调用:

{
  "service_a": ["api_name_1", "api_name_2"],
  "service_b": ["api_name_1", "api_name_2"]
}

代码运行

随后,使用下列代码即可生成您的专属阿里云OpenAPI MCP Server:

from mcp.server.fastmcp import FastMCP
from alibaba_cloud_ops_mcp_server.tools import api_tools

def main():
    mcp = FastMCP(“Example MCP server”)
    config = {
        ‘ecs’: [‘DescribeInstances’, ‘DescribeRegions’],
        ‘vpc’: [‘DescribeVpcs’, ‘DescribeVSwitches’]
    }
    api_tools.create_api_tools(mcp, config)
    mcp.run(transport=‘sse’)
    
if name == “main”:
    main()

运行命令

# Linux/MacOS
ALIBABA_CLOUD_ACCESS_KEY_ID=ak ALIBABA_CLOUD_ACCESS_KEY_SECRET=sk uv run server.py
# Windows
set ALIBABA_CLOUD_ACCESS_KEY_ID=ak && set ALIBABA_CLOUD_ACCESS_KEY_SECRET=sk && uv run server.py

程序默认通过以下端口提供服务,提供sse连接:

http://127.0.0.1:8000/sse

Client配置

选择Cherry-Studio或者 Cline等常用的MCP Client,配置sse url即可开始体验。

以Cline为例:

填写后即可完成配置

Cherry-Studio

至此,您就拥有了一个亲手搭建的专属阿里云OpenAPI MCP Server,兼具操作便捷性与可拓展性,您还可以随时对其支持的Tools进行修改,仅需调整Config中的服务及对应的API即可。

四、总结与展望

在本文中,我们系统性地介绍了如何用10行 Python 代码构建一个专属阿里云Open API MCP Server,主要提到了三个核心的亮点:

  • 无需重复繁琐的Tools编写过程
  • 无需了解阿里云的OpenAPI实现细节
  • 极大降低自定义MCP Server的编写门槛

相信上述几点能够推动用户更便捷的创建和开发MCP Server,为MCP的发展贡献力量。

未来,我们希望能够拓展场景,不止局限于阿里云的OpenAPI,只要是具备标准格式,包含API必要信息的元数据,都可以通过本文所阐述的方式进行转换和MCP Server工具的自动注册。

同时,可以看到,即便本文所提出的方案降低了MCP Server开发的门槛,简化了操作流程,但是仍局限于一个API对应一个工具的思想,未来将会尝试设计通用方案,不再针对单个API进行工具适配,而是提供基准且通用的工具,AI能够借助通用工具进行自动找寻目标API,自动检索API信息,自动填入必需参数并调用检索到的API,真正实现:固定的工具--通用的API调用。

相关阅读:

参考链接:

[1]https://github.com/aliyun/alibaba-cloud-ops-mcp-server

[2]https://swagger.io/specification/v2/

[3]https://json-schema.org/specification.html


还有一个更高级的方法,就是使用中间件。你可以设计一个中间件接口,然后实现不同的中间件,用于处理不同的逻辑。在调用API之前,依次执行这些中间件。这种方式可以实现高度的模块化和可配置性,但实现起来也比较复杂。感觉就像是搭积木一样,根据需要组装不同的功能。

从工程角度来看,通用API调用方案的复杂性会大大增加。需要构建一个足够灵活和可扩展的框架,能够支持各种不同的API和数据格式。此外,还需要考虑性能问题,如何保证AI能够快速地检索和调用API,避免成为瓶颈。感觉这会是一个很大的工程项目。

我想到的是各种第三方API服务,比如支付、短信、地图等等。如果能把这些API都抽象成统一的工具,开发者就不用为了接入不同的服务而学习不同的API接口了,想想就觉得很方便!甚至可以做成一个’万能API’平台,哈哈,有点科幻了。

这个问题很有意思!我觉得通用API调用方案最大的挑战在于如何让AI理解不同API的语义和参数差异。即使API具有标准格式的元数据,AI也需要足够智能才能正确地将用户的意图转化为API调用。比如,同样是“获取数据”,不同API可能需要不同的认证方式,返回的数据格式也可能不同,AI需要能够根据上下文自动处理这些差异。

如果不想修改源码,可以考虑使用装饰器模式。你可以编写一个装饰器函数,用于在调用API前后执行特定的操作。然后,在create_api_tools函数中,将这个装饰器应用到生成的API工具上。这种方式更加灵活,也更容易维护。

要增加额外的逻辑,单纯修改config文件肯定是不够的。你需要修改alibaba-cloud-ops-mcp-server的代码,在调用API的前后添加你自己的处理逻辑。具体来说,你可以fork这个项目,然后修改api_tools.py文件,找到create_api_tools函数,在里面添加你的代码。不过这种方式需要你对Python和MCP Server有一定的了解。

我同意楼上的观点,语义理解是关键。另一个挑战是安全性。如果AI可以随意调用API,那么权限管理就变得非常重要。如何确保AI只能访问其被授权的资源,防止恶意调用或数据泄露,是一个需要认真考虑的问题。要做到既通用又安全,感觉难度不小!

除了云服务,我觉得物联网(IoT)领域也可以应用。现在有很多不同的IoT平台和设备,它们的API格式各不相同。如果能够将这些API标准化,然后用类似本文的方案集成起来,就可以方便地控制和管理各种IoT设备。

这个问题问得好!我觉得这个方案在云服务领域有很大的潜力。比如,AWS、Azure等云平台的API也可以用类似的方式进行集成。这样,开发者就可以用一套统一的工具来访问不同的云服务,大大提高开发效率。