Qwen Code 架构概览
本文档提供了 Qwen Code 架构的高层概览。
核心组件
Qwen Code 主要由两个核心包组成,并附带一套工具集,系统在处理命令行输入时会调用这些工具:
1. CLI 包 (packages/cli)
用途: 包含 Qwen Code 面向用户的部分,负责处理初始用户输入、展示最终输出以及管理整体用户体验。
核心功能:
- 输入处理: 通过多种方式处理用户输入,包括直接文本输入、斜杠命令(如
/help、/clear、/model)、at 命令(@file用于引入文件内容)以及感叹号命令(!command用于执行 Shell 命令)。 - 历史记录管理: 维护对话历史,并支持会话恢复等功能。
- 显示渲染: 在终端中格式化并展示响应,支持语法高亮和正确的排版。
- 主题与 UI 自定义: 支持自定义主题和 UI 元素,提供个性化体验。
- 配置管理: 通过 JSON 配置文件、环境变量和命令行参数管理各项配置选项。
2. Core 包 (packages/core)
用途: 作为 Qwen Code 的后端。它接收来自 packages/cli 的请求,协调与已配置模型 API 的交互,并管理可用工具的执行。
核心功能:
- API 客户端: 与 Qwen 模型 API 通信,发送提示词并接收响应。
- 提示词构建: 为模型构建合适的提示词,整合对话历史和可用工具定义。
- 工具注册与执行: 管理可用工具的注册,并根据模型请求执行相应工具。
- 状态管理: 维护对话和会话状态信息。
- 服务端配置: 处理服务端配置与设置。
3. 工具模块 (packages/core/src/tools/)
用途: 这些是独立的模块,用于扩展 Qwen 模型的能力,使其能够与本地环境交互(例如文件系统、Shell 命令、网页抓取)。
交互方式: packages/core 根据 Qwen 模型的请求调用这些工具。
常用工具包括:
- 文件操作: 读取、写入和编辑文件
- Shell 命令: 执行系统命令,对潜在危险操作需经用户批准
- 搜索工具: 查找文件及在项目内搜索内容
- 网络工具: 从网页抓取内容
- MCP 集成: 连接 Model Context Protocol 服务器以扩展能力
交互流程
与 Qwen Code 的典型交互遵循以下流程:
- 用户输入: 用户在终端中输入提示词或命令,该过程由
packages/cli管理。 - 请求转发至 Core:
packages/cli将用户输入发送至packages/core。 - 请求处理: Core 包执行以下操作:
- 为已配置的模型 API 构建合适的提示词,可能包含对话历史和可用工具定义。
- 将提示词发送至模型 API。
- 模型 API 响应: 模型 API 处理提示词并返回响应。该响应可能是直接回答,也可能是请求使用某个可用工具。
- 工具执行(如适用):
- 当模型 API 请求使用工具时,Core 包准备执行该工具。
- 如果请求的工具会修改文件系统或执行 Shell 命令,系统会先向用户展示工具详情及其参数,用户必须批准后方可执行。
- 只读操作(如读取文件)可能无需用户显式确认即可继续。
- 确认后(或无需确认时),Core 包在对应工具中执行相关操作,并将结果返回给模型 API。
- 模型 API 处理工具执行结果并生成最终响应。
- 响应返回至 CLI: Core 包将最终响应发送回 CLI 包。
- 向用户展示: CLI 包格式化响应并在终端中展示给用户。
配置选项
Qwen Code 提供多种配置其行为的方式:
配置层级(按优先级排序)
- 命令行参数
- 环境变量
- 项目配置文件 (
.qwen/settings.json) - 用户配置文件 (
~/.qwen/settings.json) - 系统配置文件
- 默认值
主要配置类别
- 常规设置: vim 模式、首选编辑器、自动更新偏好
- UI 设置: 主题自定义、横幅可见性、页脚显示
- 模型设置: 模型选择、会话轮次限制、压缩设置
- 上下文设置: 上下文文件名、目录包含规则、文件过滤
- 工具设置: 审批模式、沙箱机制、工具限制
- 隐私设置: 使用统计数据收集
- 高级设置: 调试选项、自定义 Bug 报告命令
核心设计原则
- 模块化: 将 CLI(前端)与 Core(后端)分离,支持独立开发及未来的潜在扩展(例如为同一后端开发不同的前端)。
- 可扩展性: 工具系统采用可扩展设计,允许通过自定义工具或集成 MCP 服务器来添加新功能。
- 用户体验: CLI 专注于提供丰富且交互性强的终端体验,具备语法高亮、可自定义主题和直观的命令结构等特性。
- 安全性: 针对潜在危险操作实现审批机制,并提供沙箱选项以保护用户系统。
- 灵活性: 支持多种配置方式,能够适应不同的工作流和环境。
Last updated on