首页 文章 精选 留言 我的

精选列表

搜索[网站开发],共10000篇文章
优秀的个人博客,低调大师

Solon AI 开发学习 6 - chat - 两种 http 流式输入输出

http 流式输出(主要是指文本流式输出),需要使用响应式接口和支持流输出的 mime 声明。常见的有两种文本流式输出: 1、输出 sse(Server Sent Event) 输出的格式:以 sse 消息块为单位,以"空行"为识别间隔。 示例代码: import org.noear.solon.annotation.Mapping; import org.noear.solon.annotation.Produces; import org.noear.solon.core.util.MimeType; import org.noear.solon.web.sse.SseEvent; import reactor.core.publisher.Flux; import java.io.IOException; @Produces(MimeType.TEXT_EVENT_STREAM_UTF8_VALUE) @Mapping("case1") public Flux<SseEvent> case1(String prompt) throws IOException { return Flux.from(chatModel.prompt(prompt).stream()) .filter(resp -> resp.hasContent()) .map(resp -> new SseEvent().data(resp.getContent())); } 输出效果如下(sse 消息块有多个属性,data 为必选,其它为可选): data:{"role":"ASSISTANT","content":"xxx"} data:{"role":"ASSISTANT","content":"yyy"} 2、输出 ndjosn(Newline-Delimited JSON) 输出的格式:以 json 消息块为单位,以"换行符"为识别间隔。 import org.noear.solon.ai.chat.message.AssistantMessage; import org.noear.solon.annotation.Mapping; import org.noear.solon.annotation.Produces; import org.noear.solon.core.util.MimeType; import reactor.core.publisher.Flux; import java.io.IOException; @Produces(MimeType.APPLICATION_X_NDJSON_UTF8_VALUE) @Mapping("case2") public Flux<AssistantMessage> case2(String prompt) throws IOException { return Flux.from(chatModel.prompt(prompt).stream()) .map(resp -> resp.getMessage()); } 输出效果如下: {"role":"ASSISTANT","content":"xxx"} {"role":"ASSISTANT","content":"yyy"} 3、获取 上面讲的是作为 server 以流式输出。solon-net-httputils 则提供了,作为客户端接收流式获取(或接收)的能力: 使用 HttpUtils 获取文本行流(比如 ndjosn) Publisher<String> publisher = HttpUtils.http("http://localhost:8080/stream") .execAsLineStream("GET"); 使用 HttpUtils 获取 ServerSentEvnet (简称:sse)文本流 Publisher<ServerSentEvent> publisher = HttpUtils.http("http://localhost:8080/sse") .execAsSseStream("GET");

优秀的个人博客,低调大师

Solon AI 开发学习 4 - chat - 模型实例的构建和简单调用

聊天模型接口(ChatModel)支持: 同步调用(call),一次性返回结果 支流式调用(stream,基于 reactivestreams 规范)。通过sse或x-ndjson流式返回结果。 Tool Call(或 Function Call) 与本地数据互动(需要 llm 支持) 提示语多消息输入输出(记忆体) 带图片消息 与 solon-flow 结合使用 1、聊天模型的构建 配置方式构建 solon.ai.chat: demo: apiUrl: "http://127.0.0.1:11434/api/chat" # 使用完整地址(而不是 api_base) provider: "ollama" # 使用 ollama 服务时,需要配置 provider model: "llama3.2" headers: x-demo: "demo1" 代码: import org.noear.solon.ai.chat.ChatConfig; import org.noear.solon.ai.chat.ChatModel; import org.noear.solon.annotation.Bean; import org.noear.solon.annotation.Configuration; import org.noear.solon.annotation.Inject; @Configuration public class DemoConfig { @Bean public ChatModel build(@Inject("${solon.ai.chat.demo}") ChatConfig config) { return ChatModel.of(config).build(); } } 手动方式构建 @Configuration public class DemoConfig { @Bean public ChatModel build() { return ChatModel.of("http://127.0.0.1:11434/api/chat") //使用完整地址(而不是 api_base) .provider("ollama") .model("llama3.2") .headerSet("x-demo", "demo1") .defaultOptionAdd("stream_options", Utils.asMap("include_usage", true)) .build(); } } 2、同步调用(call) public void case1() throws IOException { ChatResponse resp = chatModel.prompt("hello").call(); //打印消息 log.info("{}", resp.getMessage()); } 3、异步流式或响应式调用(stream) 流式返回为org.reactivestreams.Publisher(reactivestreams 规范) public void case2() throws IOException { Publisher<ChatResponse> publisher = chatModel.prompt(ChatMessage.ofUser("hello")).stream(); //return publisher; //使用 solon-web-rx 时可直接返回;或者对接 solon-web-sse 或 websocket publisher.subscribe(new SimpleSubscriber<ChatResponse>() .doOnNext(resp -> { log.info("{}", resp.getMessage()); }).doOnComplete(() -> { log.debug("::完成!"); }).doOnError(err -> { log.error("{}", err); })); } 可以直接订阅消费(如上)。也可对接各种流行的响应式框架,比如 mutiny、rxjava 或 reactor: @Produces(MimeType.TEXT_EVENT_STREAM_UTF8_VALUE) @Mapping("case2") public Flux<SseEvent> case2(String prompt) throws IOException { return Flux.from(chatModel.prompt(prompt).stream()) .map(resp -> resp.getMessage()) .map(msg -> new SseEvent().data(msg.getContent())) .doOnError(err->{ log.error("{}", err); }); } 4、模型日志 内部默认会打印 llm 请求与响应的日志,分别以ai-request:和ai-response:开头。日志级别为:DEBUG。

资源下载

更多资源
Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册