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

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

相关推荐
OneThingAI2 小时前
网心算力云上线 DeepSeek-V4-Pro
人工智能·aigc·deepseek·onethingai
拾贰_C4 小时前
【Github | GitHub Copilot | 学生认证】 GitHub Copilot学生如何认证
github
旅之灵夫5 小时前
【GitHub项目推荐--OpenArm:开源7自由度仿人机械臂平台】
github
一乐小哥6 小时前
坚持迭代一个 Chrome 插件半年后,我的同事问我:"这不是 Chrome 自带的功能吗?"
chrome·github·ai编程
Smilezyl6 小时前
一个独立开发者,靠一份 markdown 驱动 Claude Code, 用 20 天跑通 9 个包的 monorepo 工程
前端·人工智能·github
峰向AI6 小时前
做小红书、画信息图、动漫图:这个skill太实用了
github
Cosolar6 小时前
封神级 TTS!VoxCPM2 凭连续表征,玩转多语言合成 + 创意音色 + 无损声纹克隆
人工智能·llm·github
码流怪侠6 小时前
【GitHub】andrej-karpathy-skills:让 AI 编程助手告别三大通病
人工智能·程序员·github