news 2026/5/6 23:07:25

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 14:13:56

如何用Animeko打造你的专属动漫追番系统

还在为追番体验不够流畅而烦恼吗&#xff1f;Animeko作为一款基于Kotlin Multiplatform技术构建的跨平台动漫应用&#xff0c;重新定义了现代追番方式。这款工具集番剧发现、智能播放、弹幕互动于一体&#xff0c;为动漫爱好者提供真正的一站式解决方案。 【免费下载链接】anim…

作者头像 李华
网站建设 2026/5/6 20:50:33

STM32启动流程

STM32的启动流程是从上电复位到进入用户main()函数的一系列关键初始化过程&#xff0c;它确保了硬件和软件环境正确建立。这个过程主要由硬件自动完成和启动文件&#xff08;.s汇编文件&#xff09;引导执行。 一、启动流程核心步骤 整个流程可以概括为以下几个关键阶段&…

作者头像 李华
网站建设 2026/5/1 10:38:43

收藏备用!AI产品经理入门全解析,大模型时代必看指南

在大模型技术爆发的当下&#xff0c;AI产品经理已成为科技圈的热门岗位。不少程序员和职场小白都想入局&#xff0c;但先得搞清楚&#xff1a;**AI产品经理到底是什么&#xff1f;它和我们熟悉的传统互联网产品经理有何不同&#xff1f;**这篇文章就从定义、分类、技能到入行路…

作者头像 李华
网站建设 2026/5/5 5:18:49

COLMAP技术突破:医疗3D解剖重建实战应用全解析

COLMAP技术突破&#xff1a;医疗3D解剖重建实战应用全解析 【免费下载链接】colmap COLMAP - Structure-from-Motion and Multi-View Stereo 项目地址: https://gitcode.com/GitHub_Trending/co/colmap 你是否曾经面对复杂的手术解剖结构感到无从下手&#xff1f;是否因…

作者头像 李华
网站建设 2026/4/25 18:49:17

Vue-Pure-Admin环境配置完全指南:从零掌握多环境管理

Vue-Pure-Admin环境配置完全指南&#xff1a;从零掌握多环境管理 【免费下载链接】vue-pure-admin 全面ESMVue3ViteElement-PlusTypeScript编写的一款后台管理系统&#xff08;兼容移动端&#xff09; 项目地址: https://gitcode.com/GitHub_Trending/vu/vue-pure-admin …

作者头像 李华