AgentScope Java 开发入门:创建一个带工具的ReAct Agent 示例
haoteby 2025-10-23 02:19 2 浏览
AgentScope-Java 为 Java 开发者提供最低学习门槛的 AI 开发框架。
它的架构有两层,在核心编排层:
- 提供 Agentic API,开发者能够声明式地定义 Agent 的记忆、决策、工具调用等能力,代码复用明显提升;
- 原生支持 MCP 协议,便于扩展工具与伙伴智能体;
- 支持流式通信,端到端的交互延迟显著降低;
- 支持 Human-in-the-loop,把关键决策交回给人审核。
在安全运行时层面:
- 它提供沙箱隔离,阻断越权工具调用;
- 提供上下文管理,动态维护短期状态与长期记忆;
- 并且原生支持 A2A,实现分布式多 Agent 自动编排与协作。
一、开发示例
这是一个基于 AgentScope 框架的 ReAct 智能体示例,实现了带工具调用功能的对话机器人。
- 智能体架构
- 使用 ReAct(Reasoning and Acting)模式,结合推理和行动
- 支持并行工具调用,提高执行效率
- 集成 DashScope 千问大模型作为推理引擎
代码定义了三个实用工具:
- 时间工具 (get_time):获取当前系统时间
- 随机数工具 (get_random):生成指定范围内的随机整数,包含参数验证和交换逻辑
- 回显工具 (echo):简单的文本回显功能
每个工具都使用 @Tool 和 @ToolParam 注解进行标注,方便框架自动识别和调用。
/**
* 带有 3 个简单工具的 ReActAgent 示例。单个用户请求可以触发多个工具。工具包括:
* 1) get_time(zone): 返回当前时间字符串
* 2) get_random(min,max): 返回 [min, max] 范围内的随机整数
* 3) echo(text): 回显给定的文本
*/
public class ReActAgentWithToolsExample {
// 日志记录器,用于输出日志信息
private static final Logger log = LoggerFactory.getLogger(ReActAgentWithToolsExample.class);
// 定义简单工具类,包含三个工具方法
public static class SimpleTools {
// 获取当前时间的工具方法
@Tool(name = "get_time", description = "Get current time string")
public String getTime() {
LocalDateTime now = LocalDateTime.now();
return now.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
}
// 获取随机数的工具方法
@Tool(name = "get_random", description = "Get a random integer in [min, max]")
public int getRandom(
@ToolParam(description = "Min value", required = true) Integer min,
@ToolParam(description = "Max value", required = true) Integer max) {
// 设置默认值,如果参数为空则使用默认值
int lo = min != null ? min : 0;
int hi = max != null ? max : 100;
// 确保最小值小于最大值
if (hi < lo) {
int t = lo; lo = hi; hi = t;
}
// 生成并返回随机数
return lo + new Random().nextInt(hi - lo + 1);
}
// 回显文本的工具方法
@Tool(name = "echo", description = "Echo back the given text")
public String echo(@ToolParam(description = "Text to echo", required = true) String text) {
return text == null ? "" : text;
}
}
public static void main(String[] args) throws Exception {
// 从环境变量获取 DashScope API 密钥
String dashApiKey = System.getenv("DASHSCOPE_API_KEY");
if (dashApiKey == null || dashApiKey.isEmpty()) {
log.warn("未找到 API 密钥。请设置 DASHSCOPE_API_KEY 环境变量。");
return;
}
// 创建工具包实例
Toolkit toolkit = new Toolkit();
// 将自定义工具类注册到工具包中
toolkit.registerTool(new SimpleTools());
// 创建内存管理器,用于存储对话历史
InMemoryMemory memory = new InMemoryMemory();
// 使用建造者模式构建 ReAct Agent
ReActAgent agent = ReActAgent.builder()
.name("Friday") // 设置Agent名称为 Friday
.sysPrompt("You are a helpful assistant named Friday. You can call tools in parallel when needed.") // 设置系统提示词
.toolkit(toolkit) // 设置工具包
.memory(memory) // 设置内存管理器
.model(DashScopeChatModel.builder() // 配置 DashScope 聊天模型
.apiKey(dashApiKey) // 设置 API 密钥
.modelName("qwen-max") // 设置模型名称
.stream(true) // 启用流式输出
.enableThinking(false) // 禁用思考模式
.defaultOptions(new GenerateOptions()) // 设置默认生成选项
.build())
.formatter(new DashScopeChatFormatter()) // 设置消息格式化器
.parallelToolCalls(true) // 启用并行工具调用
.build();
// 创建缓冲读取器,从标准输入读取用户输入
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
// 进入交互循环,直到用户输入 "exit" 退出
while (true) {
System.out.print("User> "); // 显示用户输入提示符
String line = reader.readLine(); // 读取用户输入
if (line == null || "exit".equalsIgnoreCase(line.trim())) {
break;
}
// 创建用户消息对象
Msg userMsg = Msg.builder().role(MsgRole.USER).textContent(line).build();
// 调用 Agent 的回复方法,获取响应消息
Mono<Msg> mono = agent.reply(userMsg);
// 阻塞等待消息返回
Msg msg = mono.block();
// 输出 Agent 的回复消息,使用 JSON 格式化输出
System.out.println("Friday> " + new Gson().toJson(msg));
}
// 输出退出日志
log.info("Bye.");
}
}
二、启动应用
启动应用进行测试验证:
- 命令行交互界面,支持实时对话
- 输入 "exit" 退出程序
- 使用 JSON 格式输出代理回复,便于调试
如下是测试过程:
相关推荐
- 统统都能轻松装下。_如何安装统赢
-
今天必须来好好聊聊迈腾甄选款的外观升级优势,简直是把经典与时尚玩明白了!迈腾甄选款巧妙地保留了迈腾的经典气场和造型,就像一位历经岁月沉淀却风采依旧的绅士。2871mm的超长轴距搭配超短前后悬设计,这就...
- 麒麟操作系统常见问题:打开火狐浏览器提示没有安装flash插件
-
关键词:火狐浏览器、flash、插件、安装问题类型:...
- VS Code 新手必装插件清单_vs code 安装插件
-
以下是针对VSCode新手的必装插件清单,覆盖代码编辑、效率提升、美化等核心需求,适用于大多数开发场景:一、基础必备插件Chinese(Simplified)(简体中文)功能:将VSC...
- 开源JSON可视神器,让阅读JSON变得简单!-JSONHero
-
众所周知,现在有不少代码编辑器以及在线工具,都支持JSON格式化,因此这一特性,已经不能称的上是亮点。调试工具已经成为每个开发者不可或缺的“利器”。但是,你见过能直接可视化JSON数据,把整个...
- 在NAS上部署Barcode服务_nas basic
-
部署基于BWIP-JS的条形码生成APIBWIP-JS是一个优秀的JavaScript条形码生成库,它支持多种条形码类型,并且可以运行在Node.js环境下,非常适合用来构建API服务。...
- 详细介绍一下Python如何对JSON格式数据进行处理?
-
在Python中对于JSON数据的处理是在日常开发中的常见需求之一。通常情况下,对JSON数据的处理主要涉及到如下的的几个步骤对于JSON数据的解析操作对于JSON数据的处理操作对于JSON数据的格式...
- golang2021数据格式(69)Go语言将结构体数据保存为JSON格式数据
-
JSON格式是一种对象文本格式,是当前互联网最常用的信息交换格式之一。在Go语言中,可以使用json.Marshal()函数将结构体格式的数据格式化为JSON格式。想要使用json...
- 一个vsCode格式化插件_vscode 格式化文档
-
ESlint...
- 自己抓取家中IPTV组播地址,不用交换机或多网卡,远程抓取更方便
-
通过IPTV播放应用在电视、电脑或者手机观看家中的IPTV电视直播,可以摆脱IPTV机顶盒的限制,方便在家中多台电视或者手机电脑上观看IPTV电视直播。运营商IPTV的电视直播信号稳定、高清,和互联网...
- 扣子免费系列教程, 如何使用扣子(coze)对接飞书多维表格?
-
一、说明大家都知道使用扣子(coze)把一些文本内容转为小红书风格很方便。但每次都是复制粘贴。很麻烦那能不能批量呢?今天我们就来学习下,使用扣子(coze)平台完成内容的批量转换。基本思路是读取飞书多...
- 1024程序员节 花了三个小时调试 集合近50种常用小工具 开源项目
-
开篇1024是程序员节了,本来我说看个开源项目花半个小时调试之前看的一个不错的开源项目,一个日常开发常常使用的工具集,结果花了我三个小时,开源作者的开源项目中缺少一些文件,我一个个在网上找的,好多坑...
- 办公人必看!3分钟搞定JSON/XML/Markdown,格式转换竟如此简单!
-
你是不是也遇到过这些情况:领导突然甩来一份密密麻麻的数据文件,要你半小时内整理成报表;想写技术文档,却被Markdown的语法搞得头大;或者同事发来的JSON文件,打开全是“{”“}”“,”,看得眼花...
- 开发者必备!zerotools.top全栈效率神器
-
强烈建议开发者们收藏https://zerotools.top,用它来提升日常效率。一、功能覆盖:从数据到图像的全栈支持Zerotools.top的最大亮点,是其功能维度的完整性。根据最新页面...
- 15 个非常好用的 JSON 工具_json tools
-
JSON(JavaScriptObjectNotation)是一种流行的数据交换格式,已经成为许多应用程序中常用的标准。无论您是开发Web应用程序,构建API,还是处理数据,使用JSON工具可以大...
- C#.NET Newtonsoft.Json 详解_c# jsonresult
-
简介Newtonsoft.Json(又称...