🔥 Java 的 LLM 框架,Agents-Flex v1.1.9 发布
Agents-Flex: 一个基于 Java 的 LLM 应用开发及编排框架。
经过近 1 年的开发和迭代,Agents-Flex 发布了 30+ 个版本,终于迎来了 v1.0.0 正式版本。
与此同时,基于 Agents-flex 开发的对标 Dify Coze 等产品的 AIFlowy 也正式对外开源,开源地址: https://gitee.com/aiflowy/aiflowy
Agents-Flex 的基本能力
- LLM 的访问能力
- Prompt、Prompt Template 定义加载的能力
- Function Calling 定义、调用和执行等能力
- 记忆的能力(Memory)
- Embedding
- Vector Store
- 文档处理
- 加载器(Loader)
- Http
- FileSystem
- 分割器(Splitter)
- 解析器(Parser)
- PoiParser
- PdfBoxParser
- 加载器(Loader)
- Chain 执行链
- SequentialChain 顺序执行链
- ParallelChain 并发(并行)执行链
- LoopChain 循环执行连
- ChainNode
简单对话
使用 OpenAi 大语言模型:
@Test public void testChat() { OpenAiLlmConfig config = new OpenAiLlmConfig(); config.setApiKey("sk-rts5NF6n*******"); Llm llm = new OpenAiLlm(config); String response = llm.chat("请问你叫什么名字"); System.out.println(response); }
使用 “通义千问” 大语言模型:
@Test public void testChat() { QwenLlmConfig config = new QwenLlmConfig(); config.setApiKey("sk-28a6be3236****"); config.setModel("qwen-turbo"); Llm llm = new QwenLlm(config); String response = llm.chat("请问你叫什么名字"); System.out.println(response); }
使用 “讯飞星火” 大语言模型:
@Test public void testChat() { SparkLlmConfig config = new SparkLlmConfig(); config.setAppId("****"); config.setApiKey("****"); config.setApiSecret("****"); Llm llm = new SparkLlm(config); String response = llm.chat("请问你叫什么名字"); System.out.println(response); }
历史对话示例
public static void main(String[] args) { SparkLlmConfig config = new SparkLlmConfig(); config.setAppId("****"); config.setApiKey("****"); config.setApiSecret("****"); Llm llm = new SparkLlm(config); HistoriesPrompt prompt = new HistoriesPrompt(); System.out.println("您想问什么?"); Scanner scanner = new Scanner(System.in); String userInput = scanner.nextLine(); while (userInput != null) { prompt.addMessage(new HumanMessage(userInput)); llm.chatStream(prompt, (context, response) -> { System.out.println(">>>> " + response.getMessage().getContent()); }); userInput = scanner.nextLine(); } }
Function Calling
- 第一步:通过注解定义本地方法
public class WeatherUtil { @FunctionDef(name = "get_the_weather_info", description = "get the weather info") public static String getWeatherInfo( @FunctionParam(name = "city", description = "the city name") String name ) { //在这里,我们应该通过第三方接口调用 api 信息 return name + "的天气是阴转多云。 "; } }
- 第二步:通过 Prompt、Functions 传入给大模型,然后得到结果
public static void main(String[] args) { OpenAiLlmConfig config = new OpenAiLlmConfig(); config.setApiKey("sk-rts5NF6n*******"); OpenAiLlm llm = new OpenAiLlm(config); FunctionPrompt prompt = new FunctionPrompt("今天北京的天气怎么样", WeatherUtil.class); FunctionResultResponse response = llm.chat(prompt); Object result = response.getFunctionResult(); System.out.println(result); //"北京的天气是阴转多云。 " }
Agents-Flex v1.0.9~1.1.9 更新记录:
- 新增:新增 rerank 模型的相关模块
- 新增:Milvus 支持非向量查询功能
- 新增:阿里云增加余弦相似度得分回显
- 新增: 为 ChainStartEvent 和 ChainResumeEvent 添加获取初始化参数的功能
- 新增: StreamResponseListener 添加 onMatchedFunction 方法
- 新增: 添加 openai 兼容 api 的其他第三方 api 测试
- 新增:新增 NodeErrorListener 用于监听 node 的错误情况
- 优化:重构 ChainErrorListener 的参数顺序
- 优化:优化 getParameterValues 的默认值获取
- 优化: 添加 FunctionPrompt 的 toString 方法
- 优化: 优化 ImagePrompt 的方法
- 优化: 优化 ToolPrompt 支持多个方法调用
- 优化: 优化 Stream 模型下的 Function Call
- 优化: 优化 SseClient 的 tryToStop 方法
- 优化: 优化 FunctionCall 以及添加 toString 方法
- 优化: 优化 OpenAILlm.java
- 优化: 优化 JsExecNode 在每次执行脚本时新建一个独立 Context
- 优化: 优化 Event 的 toString
- 优化:重构 MilvusDbTest,增加非向量搜索测试用例
- 优化:适配 Ollama 0.9.0 的思考模式
- 优化:redisSearch, openSearch 相似度归一化,便于用户查看
- 优化:增强 LLM 的 markdown 包裹优化
- 优化:重命名 StringUtil.obtainFirstHasText 方法名称为 getFirstWithText
- 修复:修复了 updateInternal 方法中重复添加 data.add(dict) 的问题
- 修复:修复 Milvus Document metadata 格式不一致问题
- 修复: 修正 Milvus 下 COSINE 相似度计算方法
- 修复:使用 qwen-plus 调用 function_call 没有正确拼接大模型返回的参数问题
- 修复: 修复 DeepseekLlmUtil 类型转换错误
- 修复: HistoriesPrompt 的 toMessages 可能多次添加 systemMessage 的问题
- 修复:修复 CodeNode 的 js 无法通过 "." 调用 map 数据的问题
- 修复: node 的状态在执行时未自动变化的问题
- 修复:修复阿里云百炼 text-embedding-v3 向量化使用 milvus 使用默认向量模型导致两次维度不一致问题
- 修复:qwen3 非流式返回设置 enable_thinking 为 false
- 修复:修复大模型节点,返回 json 内容时不正确的问题
- 修复:修复 EndNode 在输出固定值时出现 NPE 的问题
源码下载

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
夜莺监控再发新版,增强业务数据监控能力
夜莺监控项目最核心的定位,是做一个告警引擎,支持多种数据源的告警。这个版本的更新主要是增加了对 MySQL 数据源的支持,进一步增强了夜莺在业务指标监控方面的能力。 之前版本的夜莺主要聚焦在 Prometheus、VictoriaMetrics、ElasticSearch 等传统监控数据源上,从上个版本引入 ClickHouse 开始,夜莺开始支持更多样化的数据源,本次版本迭代则引入了 MySQL 数据源的支持,给予了用户更大的灵活性和选择空间。 另外修复了两个 Bug: 通知媒介联系方式无法保存的问题 Elasticsearch 数据源 KQL 语法报错未显示的问题 更多改动请参考 github release 的 changelog。 升级须知 大家可以从夜莺的github releases页面下载到最新的发布包。 v6/v7版本都可以平滑升级: 建议先备份老版本的二进制、配置、integrations 目录等,留好后路,然后就可以放心大胆升级了 如果夜莺所用的DB账号有建表、改表权限,会自动更新表结构,否则就要参考代码仓库里docker/migratesql手工改表结构了 int...
- 下一篇
Apache Maven 3.9.10 发布,项目管理和构建工具
Apache Maven 3.9.10 现已发布。Apache Maven 是一个项目管理和构建工具。基于项目对象模型(POM)的概念, Maven 可以从中心位置管理项目的构建、报告和文档。 此版本更新内容如下: Bug [MNG-8096] - 不一致的依赖解析行为 并发多模块构建可能会导致失败 [MNG-8169] - MINGW 支持需要 --add-opens java.base/java.lang=ALL-UNNAMED [MNG-8248] - 警告:java.lang.System 中的受限方法已被调用 [MNG-8256] - ProjectDependencyGraph bug:在过滤的情况下, 非直接模块链接丢失 [MNG-8315] - 如果 .mvn 目录位于驱动器根目录,则 mvn.cmd 会失败 [MNG-8396] - Maven 需要很长时间才能恢复 [MNG-8711] - LifecycleDependencyResolver 中的“Duplicate artifact” Improvement [MNG-8370] - 引入 maven.repo...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS关闭SELinux安全模块
- CentOS7设置SWAP分区,小内存服务器的救世主
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- 设置Eclipse缩进为4个空格,增强代码规范
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- CentOS8安装Docker,最新的服务器搭配容器使用