阿里云百炼 + Qwen3.7 实战:手把手构建一个支持工具调用的 AI Agent

简介: 本文记录使用阿里云百炼平台+Qwen3.7-Max构建企业级AI运维助手的全过程:依托其原生Function Calling、128K上下文与多工具并行调用能力,实现稳定、合规、低成本的Agent落地,含完整代码、踩坑解析与成本实测。

前言

最近在做一个内部运维助手项目,需要 AI 不只是「聊天」,而是真正能调用外部工具、查询数据库、触发工作流——也就是现在大家说的 Agent 模式。

调研了几个平台后,最终选定了阿里云百炼(AI 创新入口)作为底座,搭配最新的 Qwen3.7-Max 模型。选它的主要原因有两点:一是百炼提供了完整的 Function Calling 支持,二是 Qwen3.7 在工具调用的指令遵循能力上比上一代有明显提升。

这篇文章记录整个搭建过程,包括踩坑经历,供有同样需求的同学参考。


一、为什么选择 Qwen3.7 + 百炼?

在动手之前,先简单说一下模型选型的考量。

目前构建 Agent 的常见选择有三类:

方案 优点 局限
OpenAI GPT-4o Function Calling 成熟,生态完善 国内访问不稳定,成本高,数据出境合规风险
本地部署开源模型 数据完全自主,零 API 费用 需要 GPU 资源,7B 以下模型工具调用不稳定
阿里云百炼 + Qwen3.7 国内网络稳定,数据不出境,工具调用能力强 生态相比 OpenAI 稍小,部分小众工具链需适配

对于企业内部应用,数据合规是硬需求,所以百炼成了首选。

Qwen3.7 相比前代的核心改进在于:

  • 长上下文窗口扩展到 128K,适合处理长对话和复杂上下文
  • 多工具并行调用,一次请求可同时触发多个函数
  • 指令遵循稳定性提升,减少 JSON 格式错误的概率

二、环境准备

开通阿里云百炼服务后,先拿到 API Key:

  1. 登录阿里云百炼控制台
  2. 在「模型广场」选择 qwen-max(即 Qwen3.7-Max)
  3. 进入「API-KEY 管理」创建新的 Key

Python 环境安装依赖:

pip install openai httpx
# 百炼兼容 OpenAI SDK,无需额外安装

百炼的 API 端点与 OpenAI 格式完全兼容,只需修改 base_url

from openai import OpenAI

client = OpenAI(
    api_key="YOUR_DASHSCOPE_API_KEY",
    base_url="https://dashscope.aliyuncs.com/compatible-mode/v1"
)

三、核心实操:构建一个带工具调用的 Agent

Step 1:定义工具(Functions)

工具调用的核心是告诉模型「你有哪些能力」。以一个查询天气+发送报告的 Agent 为例:

tools = [
    {
   
        "type": "function",
        "function": {
   
            "name": "get_weather",
            "description": "获取指定城市的实时天气信息",
            "parameters": {
   
                "type": "object",
                "properties": {
   
                    "city": {
   
                        "type": "string",
                        "description": "城市名称,如「北京」「上海」"
                    },
                    "unit": {
   
                        "type": "string",
                        "enum": ["celsius", "fahrenheit"],
                        "description": "温度单位"
                    }
                },
                "required": ["city"]
            }
        }
    },
    {
   
        "type": "function",
        "function": {
   
            "name": "send_report",
            "description": "将生成的报告发送到指定邮箱",
            "parameters": {
   
                "type": "object",
                "properties": {
   
                    "email": {
   "type": "string", "description": "收件人邮箱"},
                    "content": {
   "type": "string", "description": "报告正文"}
                },
                "required": ["email", "content"]
            }
        }
    }
]

Step 2:实现 Agent 循环

Agent 的核心是一个「思考-行动-观察」的循环(ReAct 模式):

import json

def run_agent(user_message: str):
    messages = [{
   "role": "user", "content": user_message}]

    while True:
        # 调用模型
        response = client.chat.completions.create(
            model="qwen-max",
            messages=messages,
            tools=tools,
            tool_choice="auto"
        )

        msg = response.choices[0].message

        # 如果模型决定调用工具
        if msg.tool_calls:
            messages.append(msg)  # 把模型的决策加入历史

            # 执行每个工具调用
            for tool_call in msg.tool_calls:
                function_name = tool_call.function.name
                function_args = json.loads(tool_call.function.arguments)

                # 路由到实际函数
                result = dispatch_tool(function_name, function_args)

                # 把工具返回结果加入对话
                messages.append({
   
                    "role": "tool",
                    "tool_call_id": tool_call.id,
                    "content": json.dumps(result, ensure_ascii=False)
                })
        else:
            # 模型给出最终回复
            print(f"Agent 回复:{msg.content}")
            break

def dispatch_tool(name: str, args: dict) -> dict:
    """工具路由,实际项目中替换为真实的 API 调用"""
    if name == "get_weather":
        # 替换为实际天气 API
        return {
   "city": args["city"], "temp": "25°C", "condition": "晴"}
    elif name == "send_report":
        # 替换为实际邮件发送逻辑
        return {
   "status": "success", "message": f"报告已发送至 {args['email']}"}

# 运行
run_agent("查一下北京今天的天气,然后把摘要发到 test@example.com")

Step 3:处理多轮工具调用

Qwen3.7 支持在一次推理中并行调用多个工具,上面的代码已经通过 for tool_call in msg.tool_calls 处理了这个情况。

实际测试中,当我发出「查北京和上海的天气,对比后生成报告发给我」这类请求时,模型会一次性触发两个 get_weather 调用,而非串行执行,效率有明显提升。


四、踩坑记录

坑 1:工具描述要足够精确

刚开始写工具描述时用的是「获取天气」,结果模型有时会在本可以一步完成的情况下多做推断。后来改成了更具体的描述(「获取指定城市的实时天气信息,返回温度、天气状况、湿度」),稳定性明显提升。

坑 2:tool_call_id 必须准确匹配

把工具结果加入消息时,tool_call_id 必须和模型返回的 tool_call.id 完全一致,否则 API 会报错。这个细节在官方文档里有说但容易忽略。

坑 3:大量工具时的性能问题

当工具数量超过 20 个时,模型的选择准确率会下降。建议按场景对工具分组,每次只注入当前场景需要的工具子集。


五、成本参考

百炼的计费是按 Token 算的,Qwen3.7-Max 目前有限时折扣。以我们实际项目测算:

  • 单次对话含工具调用,平均消耗约 2,000-5,000 Tokens
  • 日均 1,000 次调用,月成本在百元级别,比同等 GPT-4o 调用便宜约 60-70%

另外百炼现在对新用户有免费 Token 额度,用于前期开发测试完全够用。


总结

用阿里云百炼 + Qwen3.7 搭建 Agent 的核心流程并不复杂,关键点在于:

  1. 工具描述要精准,是影响 Agent 稳定性的核心变量
  2. 合理利用并行工具调用,减少多轮交互的延迟
  3. 做好工具路由的错误处理,Agent 在生产环境中必须有降级机制

如果你也在做类似的 AI 应用,可以去百炼的活动页面看看——新用户有超过 1 亿 Tokens 的免费额度,做 POC 验证阶段完全不用担心成本。


相关链接

---

相关文章
|
21天前
|
API 开发者
千问云上线Qwen3.7-Max,支持API与Token Plan调用!
Qwen3.7-Max是阿里云2026年发布的旗舰智能体大模型,全球评测排名第五、国产第一。支持百万级上下文与自主长程任务执行,API调用价12/36元(每百万Token),已接入千问云及Token Plan订阅服务。
794 0
|
21天前
|
存储 人工智能 弹性计算
Qwen3.7 新品特惠来袭|多模态 Plus + 旗舰 Max 双模型,低成本落地智能体开发
阿里云百炼重磅上线Qwen3.7系列:Plus版(多模态经济型)支持图文视频理解,Max版(旗舰文本模型)擅长大文档、代码与复杂推理。新用户免费领7000万Tokens,Plus推理8折、Max限时5折,全用户每日200次Max免费调用,一站式降低AI应用落地成本。
|
21天前
|
人工智能 运维 自然语言处理
阿里云百炼Qwen3.7-Max模型详解:综合能力、核心优势与订阅计划参考指南
2026年,大模型技术持续向通用化、高性能、场景化方向迭代,阿里云百炼作为一站式大模型服务平台,持续推出迭代升级的模型产品,Qwen3.7-Max便是当前主力旗舰级大模型之一。该模型依托深度优化的底层架构与大规模训练数据,在文本理解、逻辑推理、多模态交互、代码生成、长文本处理等多个维度实现能力升级,同时搭配灵活的订阅计划体系,能够适配个人开发者、中小企业、大型企业、政企机构等不同类型用户的使用需求。
704 2
|
20天前
|
缓存 人工智能 自然语言处理
阿里云Qwen3.7-Max全面评测:Agent智能体能力、计费方案与落地场景说明
2026年,AI行业正式迈入智能体(Agent)规模化落地的新阶段,能否支撑长周期自主任务、控制算力调用成本,成为企业与开发者选择大模型的两大核心标准。阿里云百炼平台重磅推出**Qwen3.7-Max**,作为通义千问系列面向智能体时代的旗舰大模型,该产品彻底突破传统对话模型的能力边界,主打长周期自主执行、全栈编程、办公自动化三大核心能力,同时搭配限时五折优惠与海量免费Token额度,大幅降低AI应用落地门槛。本文结合官方基准测试数据、功能特性、应用场景、调用方式、计费规则以及MCP集成方案,全方位解读Qwen3.7-Max,帮助个人开发者、初创团队、中大型企业全面了解这款旗舰模型
683 1
|
21天前
|
人工智能 缓存 监控
阿里云百炼上线Qwen3.7-Max,支持API与Token Plan调用,解析及配置实战指南
2026年5月,阿里云百炼平台正式上线通义千问系列最新旗舰模型**Qwen3.7-Max**,标志着国产大模型正式迈入智能体时代。作为面向Agentic时代设计的全能基座模型,Qwen3.7-Max实现了从“说得好”到“做得到”的范式跃迁,在推理、编程、长周期自主执行等核心能力上实现质的飞跃。该模型已全面支持**标准API调用**与**Token Plan订阅调用**两种方式,企业与开发者可根据自身需求灵活选择,快速接入顶级AI能力。
3130 2
|
21天前
|
人工智能 缓存 自然语言处理
阿里Qwen3.7-Max评测:Agent能力显著提升,耗时与调用成本大幅下降
阿里云百炼推出面向智能体的旗舰大模型Qwen3.7-Max,具备长周期自主执行能力,显著提升编程、办公自动化等复杂任务处理水平;支持MCP集成与多框架兼容,并以限时5折+100万Tokens免费试用大幅降低使用门槛,助力企业高效落地AI应用。在阿里云百炼平台快速体验:https://t.aliyun.com/U/fPVHqY
2070 10
|
21天前
|
人工智能 运维 物联网
零门槛玩转 AI 生图:用阿里云函数计算一键部署 ComfyUI,5 分钟生成你的专属毛绒萌宠
阿里云函数计算推出一键部署ComfyUI方案,内置Flux模型与毛绒萌宠LoRA,支持超写实毛绒玩具风格AI生图。Serverless GPU按量付费、免运维、不开机不花钱,单张图低至0.02元,5分钟极速部署,零门槛体验前沿AIGC。