找回密码
 立即注册
首页 业界区 业界 分布式智能体|A2A Agent实战

分布式智能体|A2A Agent实战

膏包 昨天 13:46
随着智能体应用的广泛应用,智能体的分布式部署、跨网络、跨框架、跨组织调用,成为当下智能体落地急需解决的问题。针对这一痛点,Google推出了Agent2Agent(简称A2A)协议,专为智能体之间的互联互通、协同协作提供标准化的解决方案。
本文基于Spring AI Alibaba框架,使用Nacos作为注册中心,落地完整的分布式智能体方案。
整体架构:

一、Nacos注册中心安装

本次选用的Nacos版本为3.2.0,安装配置流程可参考官方文档,这里不再赘述基础安装步骤。
Nacos官方地址:https://nacos.io/
二、项目依赖引入

使用官方推荐的BOM方式进行依赖管理
  1.                         com.alibaba.cloud.ai            spring-ai-alibaba-bom            1.1.2.0            pom            import                            org.springframework.ai            spring-ai-bom            1.1.2            pom            import                            com.alibaba.cloud.ai            spring-ai-alibaba-extensions-bom            1.1.2.2            pom            import                                        com.alibaba.cloud.ai        spring-ai-alibaba-agent-framework                    com.alibaba.cloud.ai        spring-ai-alibaba-starter-dashscope                    com.alibaba.cloud.ai        spring-ai-alibaba-starter-a2a-nacos            
复制代码
三、Agent服务注册配置

完成依赖引入后,需要将自定义的智能体交由Spring容器管理,同时配置Nacos注册参数,实现智能体的自动注册。
1. 配置Bean对象

本次以讲笑话的智能体jokeAgent为例
  1. @Configurationpublic class A2AAgentConfig {    @Bean(name = "jokeAgent")    public ReactAgent jokeAgent() {        // 构建通义千问API对象        DashScopeApi dashScopeApi = DashScopeApi.builder()                .apiKey(System.getenv("AliQwen_API"))                .build();        // 初始化对话模型        DashScopeChatModel chatModel = DashScopeChatModel.builder()                .dashScopeApi(dashScopeApi)                .defaultOptions(DashScopeChatOptions.builder()                        .model(DashScopeChatModel.DEFAULT_MODEL_NAME)                        .temperature(0.5)                        .maxToken(1000)                        .build())                .build();        // 创建并返回笑话智能体        return ReactAgent.builder()                .name("jokeAgent")                .model(chatModel)                .description("负责讲笑话。")                .instruction("你是一个幽默风趣、反应敏捷的笑话智能体。你的任务是根据用户的要求,讲一个轻松、健康、积极向上的短笑话。")                .build();    }}
复制代码
2. 修改application.yml配置文件
  1. spring:  application:    name: spring-ai-alibaba-a2a-server  ai:    dashscope:      api-key: ${AliQwen_API}    alibaba:      a2a:        nacos:          server-addr: 127.0.0.1:8848          username: nacos          password: nacos          registry:            enabled: true # 启用服务注册(注册本地 Agent)        server:          version: 1.0.0          card:            name: jokeAgent  # 必须与Bean名称一致            description: 专门讲笑话的智能体
复制代码
3. 注册成功校验

启动项目后,控制台出现如下日志,即代表智能体成功注册到Nacos注册中心:
  1. Auto register agent jokeAgent into Registry Nacos[127.0.0.1:8848] successfully.
复制代码
配置成功后在Nacos Console上面可以看到智能体成功注册

四、Agent远程调用

完成服务端智能体注册后,客户端即可通过A2A协议远程调用注册好的智能体,实现分布式跨服务的智能体协作。
1. 客户端依赖准备

客户端同样需要添加上述的A2A依赖
2. 远程调用代码编写

客户端调用代码如下
  1. @RestControllerpublic class RemoteAgentController {    @Resource    private AgentCardProvider agentCardProvider;    @GetMapping("test")    public void test() throws GraphRunnerException {        // 服务发现:通过AgentCardProvider 从注册中心获取Agent        A2aRemoteAgent remoteAgent = A2aRemoteAgent.builder()                .name("jokeAgent")                .agentCardProvider(agentCardProvider)                .description("可以给我讲笑话")                .build();        Optional result = remoteAgent.invoke("请给我讲一个关于小明的笑话");        result.ifPresent(state -> System.out.println(state.data().get("output")));    }}
复制代码
3. 调用效果展示

[code]哈哈,收到指令——已启动「快乐多巴胺发射器」,正在加载健康笑点模块…滴!加载完毕!
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

相关推荐

您需要登录后才可以回帖 登录 | 立即注册