本地部署deepSeek家庭医生
1. ollama
ollama是一款帮助你部署大模型的一款工具软件,在你本机离线运行,不需要联网以及复杂的配置。
优势:
- Models: 自带deepseek-r1
- 本地安全, 数据都在本地
- 用自己电脑就可以运行:省钱
- 支持多硬件 macos, linux, windows
2. ollama部署deepseek-r1
运行 ollama run deepseek-r1
3. 界面工具推荐
谷歌扩展程序 PageAssist
chatboxai
4. deepSeek概念
1. deepSeek是什么?
DeepSeek 也指由 DeepSeek 公司开发的、类似于ChatGPT的大模型智能助手。
优势:
- API更便宜
- 生态开放
- 支持本地部署
- 灵活定制
2. deepSeek离线与线上api的区别?
- 数据隐私
- 可定制化
- 不依赖网络(偏远山区信号差)
- 需要更多的硬件成本
- 需要更多维护成本
- 要求机器性能
5. 项目调用deepSeek
引入spring-ai依赖
Spring AI 是一个面向 AI 工程的应用框架。其目标是将 Spring 生态系统的设计原则(如可移植性和模块化设计)应用到 AI 领域,并推广使用 POJO(Plain Old Java Objects,普通旧式 Java 对象)作为 AI 应用构建的基本单元。
1
2
3
4
5
6
7
8
9
10
11
12<!-- 引入 SpringAI 的坐标 -->
<dependency>
<groupId>io.springboot.ai</groupId>
<artifactId>spring-ai-ollama</artifactId>
<version>1.0.3</version>
</dependency>
<dependency>
<groupId>io.springboot.ai</groupId>
<artifactId>spring-ai-ollama-spring-boot-starter</artifactId>
<version>1.0.3</version>
</dependency>Application.yml 增加配置
1
2
3
4
5
6spring:
ai:
ollama:
base-url: http://127.0.0.1:11434
chat:
model: deepseek-r1:latest增加接口测试
1
2
3
4
5
6
7
8
9
10
11
12
13
14@RestController
@RequestMapping("ollama")
public class OllamaController {
@Resource
private OllamaChatClient ollamaChatClient;
@GetMapping("/ai/chat")
public Object aiOllamaChat(@RequestParam String msg) {
// 同步调用deepseek,当前页面会卡住,直到获得所有的数据才会返回给页面
return ollamaChatClient.call(msg);
}
}测试调用
6. Ollama 定制deepseek医生角色
- 新建my_doctor_0_1 文件, 指明当前角色以及性格
1 |
|
创建模型实例, 执行
ollama create mydoctor:0.1 -f my_doctor_0_1
运行, 执行
ollama run mydoctor:0.1
Application.yml 修改配置
1
2
3
4ai:
ollama:
chat:
model: mydoctor:0.1测试
⚠️注:当前的接口调用都是同步的,如果需要服务器动态推送,可以考虑SSE或者websocket技术。
本地部署deepSeek家庭医生
http://example.com/本地部署deepSeek家庭医生/