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的内容还有很多,更加深入的内容,还需继续跟着社区老师学习一下。

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

相关推荐
小鹿软件办公26 分钟前
LibreOffice 开发者再批微软 OOXML,缺乏透明度且存在兼容问题
microsoft·libreoffice
杖雍皓1 小时前
编程范式的下一次跃迁:深度解析全新的 GitHub Copilot 独立桌面应用
github·copilot
Data-Miner1 小时前
国产AI做表工具数以轻舟Agent全新更新:新增支持火山引擎API
人工智能·microsoft·火山引擎
Terrence Shen3 小时前
demo111
microsoft
JiaWen技术圈3 小时前
GitOps 最佳实践:ArgoCD + GitHub Actions 完整落地
github·argocd
墨风如雪4 小时前
小白必看!Opencode 傻瓜式安装教程,终于把 DeepSeek 接上了!
aigc
王二麻子6664 小时前
Ctrl+V 粘贴截图,Claude Code + DeepSeek 直接烂对话?这个开源项目把坑填了
github
互联圈运营观察5 小时前
布局先行、技术深耕:国内端侧AI企业抢滩机器人与具身智能赛道
人工智能·microsoft·机器人
用户938515635075 小时前
手把手教你用 Git 管理代码:从单机到分布式,再也不怕硬盘坏了
github
難釋懷6 小时前
Nginx虚拟主机
git·nginx·github