游乐游手机版
首页/手机教程/文章详情

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

时间:2025-04-24 09:20
在容器编排领域,k3s (k8s) 无疑是备受关注的存在。本文重点介绍如何在 k3s (k8s) 环境中安装 ollama,并运行 deepseek。首先,我们需要关注一个关键的

在容器编排领域,k3s (k8s) 无疑是备受关注的存在。本文重点介绍如何在 k3s (k8s) 环境中安装 ollama,并运行 deepseek。首先,我们需要关注一个关键的 yaml 文件 —— ollama.yaml。这个文件如同整个部署流程的指挥棒,规定了各项参数和配置信息。ollama.yaml 的内容如下:

# https://cloud.tencent.com/developer/article/2495842 环境变量apiVersion: apps/v1kind: Deploymentmetadata:  labels:    app: ollama  name: ollama  namespace: moonfddspec:  strategy:    type: Recreate  replicas: 1  selector:    matchLabels:      app: ollama  template:    metadata:      labels:        app: ollama    spec:      containers:        - env:            - name: OLLAMA_HOST              value: "0.0.0.0"            - name: OLLAMA_PORT              value: "11434"            - name: OLLAMA_NUM_PARALLEL              value: "20" # 默认是1            - name: OLLAMA_ORIGINS              value: "*"            - name: OLLAMA_MODELS              value: "/root/.ollama/models"          image: 'ollama/ollama:0.5.12'          command: ["ollama", "serve"]          imagePullPolicy: IfNotPresent          name: ollama          volumeMounts:            - mountPath: /root/.ollama/models/              name: data          resources:            # nvidia.com/gpu: 1            # memory: "24Gi"            # limits:            #   cpu: 200m            #   memory: 200Mi            # requests:            #   cpu: 100m            #   memory: 100Mi        - image: 'ollama/ollama:0.5.12'          command: ["sh", "-c", "while true; do ollama run deepseek-r1:1.5b; sleep 5; done"]          imagePullPolicy: IfNotPresent          name: ollamacmd      volumes:        - name: data          hostPath:            path: /root/k8s/moonfdd/ollama/root/.ollama/models/            type: DirectoryOrCreate---apiVersion: v1kind: Servicemetadata:  labels:    app: ollama  name: ollama  namespace: moonfddspec:  ports:    - name: 11434-11434      port: 11434      protocol: TCP      targetPort: 11434      nodePort: 11434  selector:    app: ollama  type: NodePort
登录后复制

?ollama 安装与运行实际效果展示

安装和运行 ollama 的命令如下:

kubectl apply -f ollama.yaml
登录后复制

运行结果如下:

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

?Go 语言调用 deepseek 接口代码分析

仅仅运行 ollama 环境还不够,还需要有与之交互的代码来发挥其功能。这里展示了 Go 语言调用 deepseek 接口的代码:

package main

import ("bufio""bytes""encoding/json""fmt""net/http""time")

type Message struct {Role string json:"role"Content string json:"content"}

// 修改请求结构体,添加 Stream 字段type DeepSeekRequest struct {Model string json:"model"Messages []Message json:"messages"MaxTokens int json:"max_tokens,omitempty"Temperature float64 json:"temperature,omitempty"Stream bool json:"stream" // 新增流式控制字段}

// 保持其他结构体不变...

const (localAPIURL = "https://www.php.cn/link/d50b2d3afe5ec033d560dd1318b2707b")

func main() {fmt.Println("开始")requestData := DeepSeekRequest{Model: "deepseek-r1:1.5b",Messages: []Message{{Role: "user",Content: "微信公众号 福大大架构师每日一题 是谁",},},MaxTokens: 512000,Temperature: 1,Stream: true, // 启用流式模式}requestBody, err := json.Marshal(requestData)if err != nil {panic("JSON编码失败: " + err.Error())}

// 配置更合理的超时时间client := &http.Client{    Transport: &http.Transport{        DisableKeepAlives: true, // ? 关键设置:禁用连接复用        MaxIdleConns:      1,        IdleConnTimeout:   30 * time.Second,    },    Timeout: 10 * time.Minute, // 大模型响应时间较长}req, err := http.NewRequest("POST", localAPIURL, bytes.NewBuffer(requestBody))if err != nil {    panic("创建请求失败: " + err.Error())}req.Header.Set("Content-Type", "application/json")req.Header.Set("Connection", "close") // 显式关闭连接req.Close = trueresp, err := client.Do(req)if err != nil {    panic("请求发送失败: " + err.Error())}defer resp.Body.Close()// 流式响应处理if resp.StatusCode != http.StatusOK {    fmt.Printf("请求失败,状态码:%d\n", resp.StatusCode)    return}// 使用 Scanner 逐行读取流式响应scanner := bufio.NewScanner(resp.Body)scanner.Buffer(make([]byte, 1024), 10*1024*1024) // 扩大缓冲区for scanner.Scan() {    rawData := scanner.Bytes()    if len(rawData) == 0 {        continue    }    var chunk DeepSeekChunk    err := json.Unmarshal(rawData[6:], &chunk)    if err == nil {        for i := 0; i < len(chunk.Choices); i++ {            if chunk.Choices[i].Delta.Content != "" {                fmt.Print(chunk.Choices[i].Delta.Content)            }        }    }}if err := scanner.Err(); err != nil {    fmt.Printf("读取响应时发生错误: %v\n", err)}
登录后复制

}

type DeepSeekChunk struct {Choices []struct {Delta struct {Content string json:"content"} json:"delta"} json:"choices"}

运行结果如下:

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

官网运行结果如下:

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

官网不联网运行结果如下:

绝了!k3s (k8s) 安装 ollama 运行 deepseek 全流程揭秘,yaml全公开

?实际意义与展望

通过在 k3s (k8s) 上完成 ollama 的安装并运行 deepseek,以及编写 Go 语言调用接口代码这一系列操作,具有多方面的实际意义和深远的展望。从技术层面而言,这为开发者在特定的容器编排环境下集成模型服务提供了一套可参考的方法和实践经验。无论是对于后续想要在相似环境里部署其他模型,还是改进和优化当前模型的运行方式,都提供了宝贵参考范例。从应用场景角度来看,能够在这样的技术栈下调用模型进行文本处理、问答交互等,都能为诸多实际项目开发提供强大助力。比如开发智能客服系统、智能助手应用等。展望未来,这种技术实践将不断推动相关技术的发展和融合。随着模型的不断升级迭代,我们可以期待更多强大功能能够被整合进这样的环境里。同时,通过持续改进和优化 yaml 文件配置以及代码实现细节,将进一步提升系统的性能和稳定性。也相信会有更多开发者基于此进行创新和拓展,探索出更多的应用可能和技术思路。就像一颗石子投入平静湖面,会泛起层层涟漪般,这项技术实践也将在整个技术领域里引发新的探索和变革浪潮。

来源:https://www.php.cn/faq/1288388.html
上一篇深度解锁AI私有知识库:用 DeepSeek 和 RAGFlow 打造企业级智能平台 下一篇【deepseek用例生成平台-12】项目前端
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
苹果iPhone 16地震预警设置与紧急提醒教程
手机教程 · 2026-07-03

苹果iPhone 16地震预警设置与紧急提醒教程

说个现实情况:iPhone 16本身并不内置原生地震预警功能。国内用户如果想在地震到来前争取到那几十秒的逃生窗口,只能依赖第三方官方App或轻量级的微信小程序。而且,系统设置里那个“政府警报”开关,实际上只对少数国家 地区的运营商生效,在国内基本是个摆设——这一点需要提前有个心理准备。那么,具体怎么

iPhone 18批量删除联系人方法及管理技巧
手机教程 · 2026-07-03

iPhone 18批量删除联系人方法及管理技巧

先说明一个前提:iPhone 18目前尚未发布,市面上能买到的量产机型仍然是iPhone 16系列(截至2026年6月),系统运行的是iOS 17 5或iOS 18开发者测试版。也就是说,本文所有关于“批量删除联系人”的操作方法,都是基于现有iOS 17 5及iCloud服务协议验证可行的原生路径,

苹果17如何关闭照片流功能及隐私安全设置
手机教程 · 2026-07-03

苹果17如何关闭照片流功能及隐私安全设置

你可能还不知道,iPhone 17里藏着一个小功能—— "我的照片流 ",它会在你不知情的时候,把近期拍的照片自动上传到iCloud,再同步到你所有登录了同一Apple ID的设备上。问题来了:如果你的某台设备借给了别人,或者被第三方应用钻了空子,那隐私照片可能就在你没察觉的时候,悄悄溜出去了。 所以,

腾讯课堂如何修改个人昵称设置方法教程
手机教程 · 2026-07-03

腾讯课堂如何修改个人昵称设置方法教程

腾讯课堂修改昵称需在手机APP操作:进入“我的”点击头像,找到“昵称”输入新名称,支持中英文数字及常见符号,不支持空格和emoji。子账号或旧版本可能隐藏入口。保存后实时同步,未更新时刷新或重启即可。

iPhone 18设置特定通知铃声及App声音管理
手机教程 · 2026-07-03

iPhone 18设置特定通知铃声及App声音管理

每个人手机里都有那么几个App,通知音却都是一个调子。微信消息“叮咚”,日历提醒也“叮咚”,实在有些无趣。iPhone 18(搭载iOS 18 1)已经支持为每个App单独设置通知音——你想让微信响起清脆的钢琴音,日历提醒用沉稳的钟声?完全可以实现。不过有个前提:自制音频必须是 m4r格式,时长不超