Skip to content

kimi acp 子命令

kimi acp 把 Kimi Code CLI 切换到 ACP (Agent Client Protocol) 模式:在标准输入/输出上以 JSON-RPC 形式与 ACP 客户端(如 Zed、JetBrains AI Chat 等)对话,让 IDE 直接驱动 kimi 的会话、prompt 与工具调用。

sh
kimi acp

启动后命令不会打印任何 banner,立刻等待 ACP 客户端在 stdin 上发出 initialize 请求。日志会写到标准错误(以及 ~/.kimi-code/logs/ 下的诊断日志),所以 ACP 通道本身保持干净。

谁会调用它?

你通常不需要手动跑 kimi acp——这个命令是给 IDE 的子进程入口准备的。IDE 端的配置见在 IDE 中使用

能力矩阵

下表列出当前 ACP 适配层声明的能力。agentCapabilities 字段在 initialize 响应里完整返回,IDE 端可据此调整 UI。

能力取值说明
promptCapabilities.imagetrue支持 ACP image 内容块(base64 + mimeType)
promptCapabilities.audiofalse暂不支持音频 prompt
promptCapabilities.embeddedContextfalse暂不支持嵌入式资源 prompt(resource/resource_link 走文本通道)
mcpCapabilities.httptrue转发 IDE 配置的 HTTP MCP 服务
mcpCapabilities.ssefalse不支持 SSE MCP 服务,相关条目会被丢弃并写 warn 日志
loadSessiontrue支持 session/load 续接已有会话,加载时会同步回放历史
sessionCapabilities.list{}支持 session/list 枚举当前用户的会话

ACP 方法覆盖

规范把方法分为稳定面和仍在演化的不稳定面(@agentclientprotocol/sdk@0.23.0 中以 unstable_* 前缀挂载的 handler)。两部分稳定性保证完全不同——稳定面是任何生产 ACP 客户端都会用到的方法,不稳定面覆盖实验性扩展(inline-edit 预测、document 缓冲区同步、provider 管理、elicitation 等),因此分开追踪。

概览:稳定面 agent-side 实现 10/12(83%)+ client reverse-RPC 实现 4/9(44%);不稳定面只接入了 session/set_model(1/19)。 任何正常 agent 流程所需的方法(initialize → auth → new/load/resume → prompt → cancel + 文件 I/O + 工具审批)都已实现。

稳定面 agent-side — IDE → agent(10 / 12)

方法状态说明
initialize版本协商;返回 agentInfo: { name: 'Kimi Code CLI', version }、能力矩阵、authMethods
authenticate校验 method_id='login';token 缺失返回 authRequired (-32000),未知 id 返回 invalidParams (-32602)
session/new接受 cwd / mcpServers,返回 configOptions[]
session/load恢复磁盘会话并把历史以 session/update 同步回放
session/resumesession/load 的轻量兄弟方法,跳过历史回放
session/prompt接受 text / image / resource / resource_link 内容块,流式输出 agent_message_chunk
session/cancel中断当前 turn
session/list枚举磁盘会话(通过 sessionCapabilities.list = {} 公告)
session/set_mode兼容路径,与 set_config_option({configId:'mode'}) 走同一 dispatcher
session/set_config_option统一的 model / thinking / mode picker 分发
session/close
logout

稳定面 client-side reverse-RPC — agent → IDE(4 / 9)

方法状态说明
session/update流式推送 agent_message_chunk / tool_call* / plan / config_option_update / available_commands_update
session/request_permission工具审批和问题 elicitation 共用此通道
fs/read_text_filekaos 层文件读取路由到客户端(通过 fsCapabilities 公告)
fs/write_text_filekaos 层文件写入路由到客户端
terminal/create · output · release · kill · wait_for_exit终端 reverse-RPC 未接,shell 命令走本地执行

不稳定面(1 / 19)

方法状态说明
session/set_model兼容路径,等价于 set_config_option({configId:'model'})
其余 18 个方法包括 session 生命周期扩展、缓冲区同步、inline-edit 预测、provider 管理等

上述未列出的方法一律返回 methodNotFound

MCP 转发

ACP 客户端在 session/newsession/load 中提供 mcpServers 时,适配层做如下转换:

  • http → kimi 的 transport: 'http' 配置
  • stdio → kimi 的 transport: 'stdio' 配置
  • sse / acp → 丢弃并写一条 warn 日志

下一步