AI - 在命令行中尝试一下ACP(Agent Client Protocol)通信

1. 简单介绍

ACP(Agent Client Protocol)是用于标准化AI Agent与代码编辑器或IDE等客户端之间通信的开放协议。有了ACP协议之后,Code Editor与Agents就解耦了。

基于ACP的SDK目前有TypeScript-SDK,rust-SDK, Python-SDK, Kotlin-SDK, Java-SDK

这边将尝试在命令行中去体验一下TypeScript的ACP案例

2.具体说明

2.1 准备工作

  1. 下载项目

    git clone https://github.com/agentclientprotocol/typescript-sdk.git

  2. 首先需要确保电脑上已经安装了NodeJs和npm

  3. 接着使用npm -install命令安装node modules

2.2 运行项目

2.2.1 Initialization
  1. 导航到SDK sample目录, typescript-sdk-main\src\examples

  2. 运行如下命令,

    npx tsx src/examples/agent.ts

  1. Client到Agents的连接初始化,下面的图片来自ACP的官方网站,

在命令行中输入如下json进行ACP连接的建立,Client和Agents进行了关于protocol version, capacity以及身份认证方法的协商,

复制代码
{"jsonrpc":"2.0","id":0,"method":"initialize","params":{"protocolVersion":1}}
  1. Agent返回了如下的信息,

可以看出Agent不支持loadsession方法,也不支持session/close方法。

2.2.2 New session

Client和Agent需要建立一个session,然后在session中进行通信,

  1. 在命令行中输入如下的内容去创建一个新的session,

    {"jsonrpc":"2.0","id":1,"method":"session/new","params":{"cwd":"...\typescript-sdk-main\src\examples","mcpServers":[{"name":"my-mcp-server-20a6993d","command":"...\MSAIFest2025DataAnalysis\MSAIFest2025DataAnalysis.exe","args":["--stdio"],"env":[]}]}}

方法使用的是session/new,

  1. 最后建立了一个新session,同时agent端返回内容如下,
2.2.3 Prompt turn

建立好session之后,从Client可以开始向Agent端发送信息了,

  1. 在控制台输入如下内容,

    {"jsonrpc":"2.0","id":2,"method":"session/prompt","params":{"sessionId":"6b22c40d0a1966da2a01e5ecfcb9e833","prompt":[{"type":"text","text":"Can you please tell me who are you?"}]}}

方法使用的是session/prompt,同时sessionId需要替换成步骤2.2.2中建立的sessionId,

  1. Agent端返回如下信息给Client, 使用的方法是session/update,
  1. 如果Agent需要user approval操作,则还会有如下回复,方法是session/request_permission,
2.2.4 Close session

在Initialize connection阶段,Client和Agent进行了协商,从Agent返回的信息可以看出不支持session/load和session/close,

  1. 这时候如果输入如下信息,

    {"jsonrpc":"2.0","id":3,"method":"session/close","params":{"sessionId":"b5bfc8f09c6857cd425ae0f80377d472"}}

  2. 则Agent端返回结果如下所示,返回了error message "Method not found",

2.2.5 其他

这个案例中,session/load也是不支持的,

3.总结

本文简单尝试了一下在命令行中进行ACP Client和Agent通信的过程。熟悉了Client/Agent之间的传递的协议,方法,参数等,就可以开始基于ACP SDK来制作UI或者IDE extension/plugin了。ACP的内容还有很多,更加深入的内容,还需继续跟着社区老师学习一下。

本文如果哪里有错误,麻烦告之,谢谢谢谢!

相关推荐
烁34742 分钟前
Ansible中的Playbook剧本使用
github
垂钓的小鱼11 小时前
TRIZ理论是什么?萃智引擎如何将它变为工程师的AI创新助手
人工智能·microsoft
阿里嘎多学长3 小时前
2026-06-13 GitHub 热点项目精选
开发语言·程序员·github·代码托管
洛星核4 小时前
CrewAI 安装、使用方法详细全解
人工智能·github·人机交互·ai编程·agi·智能体
小溪彼岸4 小时前
初识Find Skills
aigc
小溪彼岸5 小时前
初识LLM Wiki知识库
aigc
avi91115 小时前
Unity团结引擎,但是AI Tuanjie Cowork
aigc·团结引擎·aiagent·tuanjie cowork
火山上的企鹅6 小时前
Codex实战:APP远程升级服务搭建(四)Node 服务端自动识别 APK 信息
android·服务器·git·github·qgc
小溪彼岸6 小时前
OpenCode可视化使用方式
aigc