A2A (Agent2Agent)¶
A2A 是 AgentScope 对 A2A 协议 的支持,包括客户端(调用远程 Agent)和服务端(暴露本地 Agent)两部分。
客户端:A2aAgent¶
将远程 A2A 服务作为本地 Agent 使用。
快速开始¶
import io.agentscope.core.a2a.agent.A2aAgent;
import io.agentscope.core.a2a.agent.card.WellKnownAgentCardResolver;
// 创建 A2A Agent
A2aAgent agent = A2aAgent.builder()
.name("remote-agent")
.agentCardResolver(new WellKnownAgentCardResolver(
"http://127.0.0.1:8080",
"/.well-known/agent-card.json",
Map.of()))
.build();
// 调用远程 Agent
Msg response = agent.call(userMsg).block();
配置选项¶
参数 |
类型 |
描述 |
|---|---|---|
|
AgentCard |
直接提供 AgentCard |
|
AgentCardResolver |
通过解析器获取 AgentCard |
|
Memory |
记忆组件 |
|
Hook |
钩子函数 |
AgentCard 获取方式¶
// 方式 1:直接提供
A2aAgent.builder()
.agentCard(agentCard)
.build();
// 方式 2:从 well-known 路径获取
A2aAgent.builder()
.agentCardResolver(new WellKnownAgentCardResolver(url, path, headers))
.build();
// 方式 3:从 Nacos 中发现
A2aAgent.builder()
.agentCardResolver(new NacosAgentCardResolver(nacosClient))
.build();
// 方式 4:自定义解析器
A2aAgent.builder()
.agentCardResolver(agentName -> customGetAgentCard(agentName))
.build();
从 Nacos 中自动发现 A2A 服务¶
使用 Nacos 作为 A2A 注册中心,自动从 Nacos 中发现 A2A 服务进行调用。
import io.agentscope.core.a2a.agent.A2aAgent;
import io.agentscope.core.nacos.a2a.discovery.NacosAgentCardResolver;
import com.alibaba.nacos.api.PropertyKeyConst;
import com.alibaba.nacos.api.ai.AiFactory;
import com.alibaba.nacos.api.ai.AiService;
// 设置 Nacos 地址
Properties properties = new Properties();
properties.put(PropertyKeyConst.SERVER_ADDR, "localhost:8848");
// 创建 Nacos Client
AiService aiService = AiFactory.createAiService(properties);
// 创建 Nacos 的 AgentCardResolver
NacosAgentCardResolver nacosAgentCardResolver = new NacosAgentCardResolver(aiService);
// 创建 A2A Agent
A2aAgent agent = A2aAgent.builder()
.name("remote-agent")
.agentCardResolver(nacosAgentCardResolver)
.build();
服务端:A2A Server¶
将本地 Agent 暴露为 A2A 服务。
Spring Boot 方式(推荐)¶
<dependency>
<groupId>io.agentscope</groupId>
<artifactId>agentscope-a2a-spring-boot-starter</artifactId>
<version>${agentscope.version}</version>
</dependency>
# application.yml
agentscope:
dashscope:
api-key: your-api-key
agent:
name: my-assistant
a2a:
server:
enabled: true
card:
name: My Assistant
description: 基于 AgentScope 的智能助手
@SpringBootApplication
public class A2aServerApplication {
public static void main(String[] args) {
SpringApplication.run(A2aServerApplication.class, args);
}
}
手动创建方式¶
import io.agentscope.core.a2a.server.AgentScopeA2aServer;
import io.agentscope.core.a2a.server.transport.DeploymentProperties;
// 创建 A2A Server
AgentScopeA2aServer server = AgentScopeA2aServer.builder(
ReActAgent.builder()
.name("my-assistant")
.sysPrompt("你是一个有用的助手"))
.deploymentProperties(DeploymentProperties.builder()
.host("localhost")
.port(8080)
.build())
.build();
// 获取传输处理器用于 Web 框架
JsonRpcTransportWrapper transport =
server.getTransportWrapper("JSON-RPC", JsonRpcTransportWrapper.class);
// Web 服务就绪后调用
server.postEndpointReady();
配置 AgentCard¶
import io.agentscope.core.a2a.server.card.ConfigurableAgentCard;
ConfigurableAgentCard agentCard = new ConfigurableAgentCard.Builder()
.name("My Assistant")
.description("智能助手")
.version("1.0.0")
.skills(List.of(
new AgentSkill("text-generation", "文本生成"),
new AgentSkill("question-answering", "问答")))
.build();
AgentScopeA2aServer.builder(agentBuilder)
.agentCard(agentCard)
.build();
自动注册 A2A 服务到 Nacos 注册中心¶
使用 Nacos 作为 A2A 注册中心,将 AgentScope 所提供的 A2A 服务自动注册到 Nacos 中
为
Spring Boot 方式添加(推荐)
<dependency>
<groupId>io.agentscope</groupId>
<artifactId>agentscope-a2a-spring-boot-starter</artifactId>
<version>${agentscope.version}</version>
</dependency>
<!-- 额外添加 Nacos Spring Boot starter 的依赖 -->
<dependency>
<groupId>io.agentscope</groupId>
<artifactId>agentscope-nacos-spring-boot-starter</artifactId>
<version>${agentscope.version}</version>
</dependency>
# application.yml
agentscope:
dashscope:
api-key: your-api-key
agent:
name: my-assistant
a2a:
server:
enabled: true
card:
name: My Assistant
description: An intelligent assistant based on AgentScope
# 在 `agentscope.a2a` 下添加Nacos相关配置
nacos:
server-addr: ${NACOS_SERVER_ADDRESS:127.0.0.1:8848}
username: ${NACOS_USERNAME:nacos}
password: ${NACOS_PASSWORD:nacos}
@SpringBootApplication
public class A2aServerApplication {
public static void main(String[] args) {
SpringApplication.run(A2aServerApplication.class, args);
}
}
为
手动创建方式添加
<dependency>
<groupId>io.agentscope</groupId>
<artifactId>agentscope-extensions-nacos-a2a</artifactId>
<version>${agentscope.version}</version>
</dependency>
import com.alibaba.nacos.api.PropertyKeyConst;
import com.alibaba.nacos.api.ai.AiFactory;
import com.alibaba.nacos.api.ai.AiService;
import io.agentscope.core.a2a.server.AgentScopeA2aServer;
import io.agentscope.core.a2a.server.transport.DeploymentProperties;
import io.agentscope.core.nacos.a2a.registry.NacosAgentRegistry;
// 设置 Nacos 地址
Properties properties = new Properties();
properties.put(PropertyKeyConst.SERVER_ADDR, "localhost:8848");
// 创建 Nacos Client
AiService aiService = AiFactory.createAiService(properties);
// 添加 Nacos 的 AgentRegistry
AgentScopeA2aServer server = AgentScopeA2aServer.builder(
ReActAgent.builder()
.name("my-assistant")
.sysPrompt("你是一个有用的助手"))
.deploymentProperties(DeploymentProperties.builder()
.host("localhost")
.port(8080)
.build())
.withAgentRegistry(NacosAgentRegistry.builder(aiService).build())
.build();
配置选项¶
NacosA2aRegistryProperties registryProperties = NacosA2aRegistryProperties.builder()
.setAsLatest(true)
.enabledRegisterEndpoint(true)
.overwritePreferredTransport("http")
.build();
NacosAgentRegistry agentRegistry = NacosAgentRegistry
.builder(aiService)
.nacosA2aProperties(registryProperties)
.build();
参数 |
类型 |
描述 |
|---|---|---|
|
boolean |
注册的 A2A 服务始终为最新版本,默认为 |
|
boolean |
自动注册所有 |
|
String |
注册 A2A 服务时,使用此 |
中断任务¶
// 客户端中断
agent.interrupt();
// 带消息的中断
agent.interrupt(Msg.builder()
.textContent("用户取消了操作")
.build());
更多资源¶
A2A 协议规范: https://a2a-protocol.org/latest/specification/
Agent 接口: Agent.java
Nacos 快速开始 : https://nacos.io/docs/latest/quickstart/quick-start
Nacos Java SDK : https://nacos.io/docs/latest/manual/user/java-sdk/usage
Nacos Java SDK 更多配置参数 : https://nacos.io/docs/latest/manual/user/java-sdk/properties
Nacos 社区 : https://github.com/alibaba/nacos