阿里云百炼 + 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 验证阶段完全不用担心成本。


相关链接

---

相关文章
|
17小时前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
7407 32
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
17小时前
|
数据采集 人工智能 前端开发
让 Coding Agent 从黑盒到透明:阿里云 Agent 观测审计数据采集实践
AI Agent 规模化落地带来执行黑盒、行为难追溯、成本难度量三大难题。阿里云基于 OTel 标准,面向 Coding Agent、个人通用助理和框架型 Agent,推出 LoongSuite Pilot、插件及探针等无侵入采集方案,让 Agent 实现可看见、可分析、可审计、可治理。
640 142
|
17小时前
|
人工智能 缓存 自然语言处理
阿里Qwen3.7-Max评测:Agent能力显著提升,耗时与调用成本大幅下降
阿里云百炼推出面向智能体的旗舰大模型Qwen3.7-Max,具备长周期自主执行能力,显著提升编程、办公自动化等复杂任务处理水平;支持MCP集成与多框架兼容,并以限时5折+100万Tokens免费试用大幅降低使用门槛,助力企业高效落地AI应用。在阿里云百炼平台快速体验:https://t.aliyun.com/U/fPVHqY
|
17小时前
|
人工智能 安全 定位技术
CodeGraph深度解析 让Claude Code工具调用直降七成的核心原理与实操教程
如今以Claude Code为代表的AI编程智能体已经成为开发者日常编码、项目重构、漏洞修复的必备工具。但在长期使用过程中,几乎所有开发者都会遇到同一个明显痛点:AI虽然具备强大的代码生成与分析能力,却常常陷入盲目探索的循环中。
1248 2
|
17小时前
|
人工智能 弹性计算 运维
阿里云发布堡垒机智能运维Agent,运维交互进入自然语言新时代
支持自然语言运维,提升效率与安全双保障。
1167 1
|
17小时前
|
存储 定位技术 数据库
CodeGraph 如何让 Claude Code减少 7 成工具调用?
CodeGraph 为 Coding Agent 提供本地代码知识图谱,把函数、类、调用链和框架路由提前整理成“项目地图”,减少盲目搜索和文件读取。它不是新 Agent,而是上下文基础设施,让 Agent 更快找到正确代码路径,平均减少 7 成工具调用。
1305 4
|
17小时前
|
人工智能 运维 JavaScript
阿里云Qoder CN(原通义灵码)全解析 产品形态、版本划分与技术适配说明
在AI辅助开发与智能办公工具持续普及的当下,阿里云旗下原通义灵码正式更名为Qoder CN,同时延伸出QoderWork CN、Qoder CN CLI、Qoder CN Mobile等多款配套产品,形成覆盖代码开发、日常办公、终端交互、移动端使用的完整工具矩阵。Qoder CN核心定位为AI智能编码助手,深度适配主流代码编辑器、集成开发环境以及终端场景;QoderWork CN则偏向桌面端综合办公辅助,二者面向不同使用场景,划分了多个版本档位,搭配差异化资源配额、功能权限与计费规则,同时兼容多款主流大模型。
377 4
|
17小时前
|
JavaScript 定位技术 API
CodeGraph 爆火:编程 Agent 需要的不是更多上下文,而是一张提前画好的代码地图
CodeGraph 是一款爆火的本地代码智能工具,通过 tree-sitter 解析 AST 构建结构化知识图谱(存于 SQLite),为编程 Agent 提前生成“代码地图”。它显著降低 Agent 在中大型项目中的探索成本——实测工具调用减少71%、Token 降57%、速度提升46%,支持19+语言及主流框架路由识别,完全离线、无需 API Key。
328 1
CodeGraph 爆火:编程 Agent 需要的不是更多上下文,而是一张提前画好的代码地图
|
17小时前
|
存储 安全 Java
AgentScope Java 2.0:打造分布式、企业级智能体底座
AgentScope 2.0 面向分布式部署、稳定运行、权限安全等企业级需求全面升级,打造支持多租户隔离与长期稳定运行的企业级智能体底座。
|
17小时前
|
人工智能 运维 API
2026年阿里云百炼通义千问Qwen3.7-plus深度介绍 功能特性、使用优势及618大促订阅方案指南
大模型技术的普及,让AI能力逐步融入个人办公、内容创作、代码编写、企业运营、教育培训等各类场景。不同定位的模型对应不同使用需求,旗舰级模型性能强劲但使用成本偏高,轻量化模型价格低廉却难以胜任复杂任务,而介于两者之间的中端主力模型,凭借均衡的能力、亲民的定价、广泛的场景适配性,成为绝大多数个人用户、小型团队、中小企业的首选。
450 1