Spring AI接入本地大模型Ollama

https://ollama.com/download/windows
下载一个Ollama的客户端,在官网提供了各种不同版本的Ollama,大家可以根据自己的需要下载https://ollama.com/download/windows,
在这里插入图片描述
勾选web 和ollama
在这里插入图片描述
yml

#spring.application.name=demo9
spring:
  application:
    name: demo9
  ai:
    ollama:
      base-url: http://localhost:11434  # Ollama 默认地址
      chat:
        model: deepseek-r1:1.5b  # 使用的模型名称

在这里插入图片描述

configuration
package com.example.ai.config;

import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.ollama.OllamaChatModel;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;


public class configration {
    
    public ChatClient chatClient(OllamaChatModel  model)
            {

                        return ChatClient.builder(model)
                                .build();
            }
}

编写controller

package com.example.ai.controller;


import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.chat.client.DefaultChatClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController

public class DeepSeekR1Controller {

private final ChatClient chatClient;

    public DeepSeekR1Controller(ChatClient chatClient) {
        this.chatClient = chatClient;
    }

    @GetMapping("/deepseek-chat")
    public String chat(@RequestParam String message) {
        return chatClient.prompt()
                .user(message)
                .call()
                .content();

    }
}

流式

@RequestMapping(value = "/deepseek-chat", produces = "text/html;charset=utf-8")
    public Flux<String> chatStream(String ){
        return chatClient.prompt()
                .user(m) 
                .stream() 
                .content(); 
    }

运行
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

布拉多多

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值