MCP 扩展机制:OpenCode 如何通过 Model Context Protocol 接入外部工具

简介: MCP(Model Context Protocol)是连接AI编程助手与外部工具的开放协议,如数据库、API、Jira、Salesforce等。它通过标准化“插头”式接口,支持本地/远程服务器接入,实现安全、灵活、按需调用。OpenCode已深度集成MCP,助力AI真正落地业务场景。

如果你用过 OpenCode,大概已经见识过它作为 AI 编程助手的本事——读代码、写代码、跑测试、修 bug,一套流程走得挺顺。但说句实在话,再厉害的 AI 编程助手,如果只能在自己的小圈子里转悠,能做的事情终究有限。真正让它“好用”的,是能不能跟外面的世界打通——能不能查数据库、调 API、操作 Jira 工单、连 Salesforce 查客户信息。

这就是 MCP 要解决的事情。

MCP 是什么?
Model Context Protocol(MCP)是一个开放协议,专门用来连接 LLM 应用和外部数据源、工具。你可以把它理解成一个标准化的“插头”——不管你在用 Claude、Cursor 还是 OpenCode,只要支持 MCP,就能用同一套方式接上各种各样的外部工具。

MCP 采用的是客户端-主机-服务器架构。听起来有点绕,拆开看就清楚了:

Host(主机) :就是 OpenCode 本身,负责创建和管理客户端、控制权限、协调 AI 模型。
Client(客户端) :主机为每个 MCP 服务器创建一个客户端,负责跟对应的服务器通信。
Server(服务器) :真正干活的地方,暴露工具、资源和提示词给 AI 用。
MCP 基于 JSON-RPC 2.0 通信,而且是无状态的——每个请求都自包含,带上协议版本、客户端标识和能力声明。这种设计让服务器可以跑在本地,也可以部署成远程服务,很灵活。

OpenCode 怎么接入 MCP?
OpenCode 对 MCP 的支持挺彻底的。你可以在 OpenCode 配置文件的 mcp 字段下定义 MCP 服务器。配置好了之后,MCP 提供的工具会自动跟 OpenCode 的内置工具合并,一起提供给 LLM 使用。

接入方式分两种:本地服务器和远程服务器。

本地 MCP 服务器
本地服务器就是把 MCP 服务器当成一个子进程跑起来,通过标准输入输出(stdio)跟 OpenCode 通信。

配置方法很简单,在 opencode.json 里加一段:

{
"mcp": {
"everything": {
"type": "local",
"command": ["npx", "-y", "@modelcontextprotocol/server-everything"]
}
}
}
这里 type 必须是 "local",command 是启动服务器的命令和参数。你还可以配置 environment 传环境变量、timeout 设超时时间(默认 5 秒)、enabled 控制是否启用。

配置好之后,在提示词里直接说“use the mcp_everything tool”就能用了。

远程 MCP 服务器
远程服务器走 HTTP 通信,适合那些部署在云端的服务。配置方式类似,只是 type 改成 "remote",再加一个 url:

{
"mcp": {
"composio": {
"type": "remote",
"url": "https://connect.composio.dev/mcp",
"headers": {
"Authorization": "Bearer YOUR_TOKEN"
}
}
}
}
远程服务器还支持 OAuth 认证。如果你的 MCP 服务器需要登录授权,可以在配置里加 oauth 字段。

一个更优雅的方式:Skill 嵌入 MCP
除了直接在全局配置里加 MCP 服务器,OpenCode 还有一个更 neat 的方式——把 MCP 服务器嵌在 Skill 里。

具体做法是在 Skill 的 markdown 文件的 YAML frontmatter 里定义 MCP 服务器:


name:my-skill
description:"A skill that uses a custom MCP server"
mcp:
my-server:
command:["npx","-y","@some/mcp-server"]
environment:

  API_KEY:"${MY_API_KEY}"

或者直接在 Skill 目录里放一个 mcp.json 文件也行。

这样做的好处是:Skill 自己管自己的 MCP 依赖,不用改全局配置。加载 Skill 的时候,插件会自动发现并连接对应的 MCP 服务器。连接是懒加载的——第一次用的时候才连,5 分钟不用自动断开清理。很省心。

一个完整的例子:接上 Salesforce
光说不练假把式。我们拿 Salesforce 举个例子,看看怎么把真实的业务工具接进 OpenCode。

用 Composio 的 MCP 网关来连 Salesforce。有两种方式:

方式一:用 Composio CLI

先装 CLI 并登录:

npx composio-cli login
然后在 OpenCode 里让 AI 去认证:

“Authenticate with Salesforce Composio”

走完浏览器里的授权流程就行了。

方式二:直接在 OpenCode 配置里加

在 opencode.json 的 mcp 字段里加:

{
"mcp": {
"composio": {
"type": "remote",
"url": "https://connect.composio.dev/mcp"
}
}
}
然后同样让 AI 去触发认证流程。

搞定之后,你就可以在 OpenCode 里直接问:

“Add new contact to spring campaign”

或者

“Clone opportunity with all associated products”

OpenCode 的 Agent 会通过 MCP 调用 Salesforce 的对应工具来完成任务。

值得注意的几个点
上下文占用:MCP 服务器会占用 LLM 的上下文空间。工具越多,占用的 token 越多。有些服务器(比如 GitHub MCP)消耗特别大,很容易撑爆上下文限制。所以别什么都往里加,按需配置。

安全边界:MCP 的设计原则之一就是服务器之间相互隔离——每个服务器只拿到它需要的信息,看不到整个对话历史,也看不到其他服务器在干什么。主机(OpenCode)负责维护这个安全边界。但工具本身可能涉及任意代码执行,调用工具之前 OpenCode 会征求用户同意。

capability 协商:MCP 用了一套能力协商机制——客户端和服务器在每次请求里声明自己支持什么功能。服务器得声明自己支持 tools,客户端才能调用工具。这套机制保证了扩展的灵活性——双方可以按需增加新能力,不用等协议升级。

小结
MCP 解决了一个很实际的问题:AI 编程助手不能活在真空中。通过 MCP,OpenCode 可以接上本地跑的命令行工具,也可以连上远端的 SaaS 服务,而且接入方式标准化了——不用为每个工具写一遍胶水代码。

配置上,你可以走全局的 opencode.json,也可以走 Skill 自带的 MCP 定义。哪种方式更适合你,取决于具体的使用场景。但不管怎么选,底层逻辑是一样的:MCP 服务器暴露工具 → OpenCode 发现并注册这些工具 → LLM 在需要的时候调用它们。

说到底,MCP 就是个“USB 接口”——让 AI 能插上各种外设,干更多活。OpenCode 把这个接口做得很扎实,剩下的就看你能接上多少好玩的东西了。

相关文章
|
4天前
|
人工智能 JSON 自然语言处理
让教学更智慧:用阿里云百炼工作流,自动生成中小学教材内容#小有可为#有温度的AI
通过可视化工作流编排,将大模型推理能力转化为标准化的教学内容生成引擎。教师只需输入教材标题和适用学段,即可自动获得结构完整、符合课程标准的章节内容,大幅降低备课门槛,助力教育资源均衡化。
446 122
|
6天前
|
人工智能 定位技术 SEO
我学 GEO 第 15 天:终于知道AI GEO该如何做?
我是暴走的莉莉酱,边旅行边研究AI GEO的数字游民。专注普通人如何提升“AI可见度”——让AI在回答用户问题时准确识别、理解并推荐你。不讲玄学,只做可测、可调、可持续的GEO实践。
430 125
|
8天前
|
机器学习/深度学习 人工智能 调度
🐴 HappyHorse 1.1 现已上线阿里云百炼!快来查收模型使用指南,现在调用享 6 折~
HappyHorse 1.1 是新一代视频生成大模型,全面升级动态表现力、角色一致性、指令遵循、视觉质感与音画协同能力。支持I2V/T2V/R2V三类生成,适配短剧、电商广告、品牌营销等场景,提供高质、流畅、可控的AI视频生产力。
718 5
🐴 HappyHorse 1.1 现已上线阿里云百炼!快来查收模型使用指南,现在调用享 6 折~
|
6天前
|
缓存 人工智能 运维
阿里云618百炼大模型Qwen3.7-Max功能、免费试用、订阅计费、配置接入详解
Qwen3.7-MAX是阿里云百炼平台推出的通义千问3.7系列旗舰大语言模型,专为智能体时代复杂任务打造,依托阿里云全域算力与自研技术,在逻辑推理、长文本处理、代码工程、长周期自主执行等领域达到行业顶尖水平。2026年618期间,该模型推出多重免费试用权益、按量计费5折、订阅套餐优惠等专属福利,覆盖个人开发者、团队与企业全场景需求,以下从核心功能、免费试用、订阅计费、配置接入四方面展开详细解析。
427 123
|
4天前
|
人工智能 自然语言处理 API
阿里云Token Plan团队版解析:功能、三档套餐与省钱订阅指南
阿里云百炼平台推出的Token Plan团队版,是面向企业与团队的AI大模型订阅服务,以Credits为统一计量单位,整合文本与图像生成模型,提供团队管理、数据安全、多工具兼容等核心能力,解决团队零散订阅AI服务的管理混乱、成本失控、数据安全等痛点。本文将从核心定位、套餐详情、计费规则、团队管理、工具兼容、便宜订阅技巧等方面,全面解析Token Plan团队版,帮助企业与团队高效、低成本地使用AI服务。
317 108
|
14天前
|
Linux 程序员 数据格式
【2026最新】Notepad++下载、安装和使用一篇搞定(附中文版安装包)
Notepad++ 是一款免费开源、轻量高效的 Windows 文本编辑器,支持 C/Python/HTML 等 80+ 语言语法高亮、代码折叠、正则替换、编码转换及插件扩展,专为程序员与文本处理用户打造,完美替代系统记事本。(239字)
|
5天前
|
存储 人工智能 数据可视化
别再手动复制 Skill 了:多 Agent 时代的 Skill 管理方案
多 Agent 场景下 Skill 的统一管理与同步。
274 125
|
8天前
|
存储 人工智能 监控
QoderWork完全指南:从入门到精通,把“AI实习生”变成你的全能工作搭档
阿里云2026年推出的桌面端AI工作助手QoderWork,不止聊天,更可动手干活:本地运行、安全可控,支持文件整理、数据分析、PPT生成、网页开发等;内置专家套件、多Agent协作与自定义Skills,让AI真正成为你身边的“AI实习生”。