在 Windows WSL 上部署 Ollama 和大语言模型:从镜像冗余问题看 Docker 最佳实践20241208

🛠️ 在 Windows WSL 上部署 Ollama 和大语言模型:从镜像冗余问题看 Docker 最佳实践

⭐ 引言

随着大语言模型(LLM)和人工智能技术的迅猛发展,开发者们越来越多地尝试在本地环境中部署模型进行实验。
但部署过程中常常会遇到 网络限制、资源冲突 和 工具复杂性 等问题。本文聚焦于实际操作中遇到的 Docker 镜像冗余问题,并总结了从问题发现到解决的完整流程。同时,结合 Ollama、Open WebUI 和 Qwen 的联系,分享一套适用于本地 LLM 部署的 Docker 最佳实践工作流,帮助开发者高效部署和管理模型。
在这里插入图片描述

🔍 Ollama、Open WebUI 和 Qwen 的联系

📌 Ollama

  • 定位:本地大语言模型推理工具,支持 RESTful API。
  • 功能:
    • 提供 LLM 模型的高效推理能力。
    • 通过命令行工具快速部署 RESTful 服务。
  • 优势:
    • 轻量化:支持 CPU 和 GPU 环境。
    • 离线能力:无需联网即可本地运行模型。

📌 Open WebUI

  • 定位:基于浏览器的交互界面,方便与模型交互。
  • 功能:
    • 提供文档导入和 RAG(检索增强生成)支持。
    • 可视化界面适合复杂任务的操作。
  • 优势:
    • 用户友好:降低命令行门槛。
    • 高扩展性:与 Ollama 的后端无缝结合。

📌 Qwen

  • 定位:阿里巴巴推出的大语言模型,支持中英文双语。
  • 功能:
    • 文本生成、理解和推理能力强大。
    • 可在 Ollama 或 Hugging Face 环境中部署。
  • 优势:
    • 任务灵活:适用于对话生成、知识问答等。
    • 开放性强:支持自定义训练与开源应用。

📎 三者的协作

  • Ollama 提供模型推理服务,并通过 API 接口供其他工具调用。
  • Open WebUI 作为用户界面,与 Ollama 的 API 交互。
  • Qwen 是核心模型,为用户提供实际生成能力。

🛠️ 镜像冗余问题:从发现到解决的完整分析

📌 问题背景

在通过 Docker 部署 Open WebUI 时,始终无法正常启动容器,日志显示 网络无法访问 Hugging Face。但实际根源是 Docker 镜像冗余 导致的容器冲突。

现象:
1. 多个停止状态的容器残留。
2. 重复镜像未清理,导致新容器启动失败。
3. 错误日志显示:

Error response from daemon: conflict: unable to delete <image_id> - image is being used by stopped container.

📋 问题排查与解决

1. 检查运行状态的容器:

docker ps -a

输出结果显示多个以相同镜像启动的容器,其中一些处于停止状态。

2. 检查镜像状态:

docker images

发现重复镜像未清理,占用存储空间,可能导致冲突。

3. 停止并删除所有相关容器:

docker stop <container_id>
docker rm <container_id>

4. 强制删除镜像:
即使镜像有残留关联容器,docker rmi 也可以强制删除:

docker rmi <image_id>

• 例如:docker rmi 7d2
此命令只需提供镜像 ID 的前几位即可,Docker 会自动匹配。

5. 删除未使用的镜像:
该命令清理所有未被使用的镜像,释放存储空间。

docker image prune -a

6. 重新加载镜像并启动容器:

  • 加载离线镜像:
docker load < x86-64-images.tar.gz
  • 启动 Open WebUI 容器
docker run -d --network=host \-v /home/<user>/.ollama/models:/app/backend/data \-e OLLAMA_BASE_URL=http://127.0.0.1:11434 \--name open-webui \--restart always \ghcr.io/open-webui/open-webui:main
  • 以下是对该 docker run 命令的逐步解读,每个选项和参数的详细说明:

**1. 基本命令:docker run **
• 启动一个新的容器实例,基于指定的镜像运行。
• 这是 Docker 最常用的命令,用于容器化服务的启动。

2. 参数解析

  • -d
    • 含义:以 后台(detached)模式 运行容器。
    • 功能:让容器在后台运行,而不是占用当前终端。
    • 优势:适合需要长期运行的服务,如 API 或 Web 应用。

  • –network=host
    • 含义:让容器直接使用主机的网络栈,而不启用 Docker 默认的桥接网络。
    • 功能:
    • 容器中的服务可直接使用主机的 IP 和端口,而不需要端口映射。
    • 网络性能更高,避免了容器和主机之间的网络虚拟化开销。
    • 注意:
    • 使用 --network=host 时,容器内的端口与主机共用,因此可能引发端口冲突。
    • 在某些场景下可能降低安全性,因为容器直接暴露于主机网络。

  • -v /home//.ollama/models:/app/backend/data
    • 含义:挂载主机目录 /home//.ollama/models 到容器中的 /app/backend/data。
    • 功能:
    • 主机的 ~/.ollama/models 目录用于存储模型文件,将其挂载到容器内的对应目录。
    • 容器运行期间可以访问主机上的模型文件,实现数据共享。
    • 优势:
    • 数据持久化:即使容器删除,模型文件仍保留在主机上。
    • 方便管理:直接在主机上更新模型文件,无需重启容器。

  • -e OLLAMA_BASE_URL=http://127.0.0.1:11434
    • 含义:通过环境变量 -e 为容器中的服务设置配置。
    • 功能:
    • 定义 OLLAMA_BASE_URL 环境变量,指定 Ollama 服务的基地址。
    • 在该示例中,http://127.0.0.1:11434 表示 Ollama 服务运行在主机的 127.0.0.1 地址和 11434 端口上。
    • 优势:
    • 配置灵活:通过环境变量可动态调整服务地址,无需修改代码或重新构建镜像。

  • –name open-webui
    • 含义:为容器指定一个唯一的名字 open-webui。
    • 功能:
    • 方便管理容器,例如 docker stop open-webui。
    • 提高可读性,相比于容器的随机 ID,容器名字更易识别。

  • –restart always
    • 含义:设置容器的重启策略为 always。
    • 功能:
    • 当 Docker 守护进程启动时,自动重启该容器。
    • 如果容器崩溃,也会自动尝试重启。
    • 优势:
    • 提高服务的稳定性和可用性,适合长时间运行的容器化服务。

  • ghcr.io/open-webui/open-webui:main
    • 含义:指定容器镜像来源。
    • 解析:
    • ghcr.io/open-webui/open-webui:镜像的路径,托管于 GitHub Container Registry。
    • main:镜像的标签,通常表示主分支的最新版本。
    • 功能:
    • Docker 会从注册表拉取 open-webui:main 镜像并创建容器。
    • 如果镜像已存在本地,则直接使用,无需重复下载。

技巧总结

    1. 缩短 ID 输入:
      无需完整输入容器或镜像的 ID,只需提供前几位即可,Docker 自动匹配:
docker rm 7eb
docker rmi 7d2
    1. 强制删除镜像:
      若提示镜像被关联容器占用,可先删除关联的容器或直接用 docker rmi 强制删除。
    1. 清理未使用资源:
      使用 docker image prune -a 一次性清理所有未使用的镜像,保持存储空间整洁。

📋 Docker 最佳实践工作流

为避免类似问题,以下是一套 系统化的 Docker 清理与部署工作流,帮助开发者优化操作流程:

📌 1. 项目初始化

1. 检查已有容器和镜像状态:

docker ps -a
docker images

2. 清理未使用的容器和镜像:

docker container prune
docker image prune -a

📌 2. 加载或拉取镜像

  • 加载离线镜像:
tar -xzvf x86-64-images.tar.gz
docker load < x86-64-images.tar.gz
  • 拉取远程镜像:
docker pull ghcr.io/open-webui/open-webui:main

📌 3. 部署并启动容器

1. 启动 Open WebUI:

docker run -d --network=host \-v /home/<user>/.ollama/models:/app/backend/data \-e OLLAMA_BASE_URL=http://127.0.0.1:11434 \--name open-webui \--restart always \ghcr.io/open-webui/open-webui:main

2. 启动 Ollama 服务:

ollama serve

📌 4. 日常维护

  • 查看容器状态:
docker ps
  • 查看容器日志:
docker logs <container_id>
  • 更新镜像:
docker pull ghcr.io/open-webui/open-webui:main

📝 结语

这次部署的最大收获在于:
1. 系统化问题分析:通过逐步排查,从网络问题定位到 Docker 镜像冲突。
2. 工具高效协作:深入理解 Ollama、Open WebUI 和 Qwen 的协作方式,充分发挥其功能。
3. 优化实践工作流:总结出了一套高效的 Docker 清理与部署流程。

希望这篇博客能为遇到类似问题的开发者提供启发和帮助。如果您有任何问题或想法,欢迎留言讨论! 🚀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/486799.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

混合云策略在安全领域受到青睐

Genetec 发布了《2025 年物理安全状况报告》&#xff0c;该报告根据超过 5,600 名该领域领导者&#xff08;其中包括 100 多名来自澳大利亚和新西兰的领导者&#xff09;的回应&#xff0c;揭示了物理安全运营的趋势。 报告发现&#xff0c;澳大利亚和新西兰的组织采用混合云策…

juc并发编程(下)

一些辅助类 减少计数CountDownLatch 设置一个计数器&#xff0c;通过countDown方法进行减1操作&#xff0c;使用await方法等待计数器不大于0&#xff0c;继续执行await方法之后的语句。 当一个或多个线程调用await方法时&#xff0c;这些线程会阻塞 其他线程调用countDown方…

调用matlab用户自定义的function函数时,有多个输出变量只输出第一个变量

很多朋友在使用matlab时&#xff0c;会使用或自己编辑多个function函数&#xff0c;来满足自己对任务处理的要求&#xff0c;但是在调用function函数时&#xff0c;会出现这个问题&#xff1a;调用matlab用户自定义的function函数时&#xff0c;有多个输出变量只输出第一个变量…

计算机毕设-基于springboot的志愿者招募管理系统的设计与实现(附源码+lw+ppt+开题报告)

博主介绍&#xff1a;✌多个项目实战经验、多个大型网购商城开发经验、在某机构指导学员上千名、专注于本行业领域✌ 技术范围&#xff1a;Java实战项目、Python实战项目、微信小程序/安卓实战项目、爬虫大数据实战项目、Nodejs实战项目、PHP实战项目、.NET实战项目、Golang实战…

嵌入式蓝桥杯学习7 产生PWM

Cubemx配置 打开cubemx&#xff0c;前面的配置看上文&#xff0c;这里主要配置定时器产生PWM波。 以PA1的TIM2-CH2通道为例进行演示。 1.在Timers中打开TIM2,将Channel2配置为PWM Generation CH2。 2.将Clock Source 选择为Internal Clock。 3.配置Paramater Settings中的参…

LobeChat-46.6k星!顶级AI工具集,一键部署,界面美观易用,ApiSmart 是你肉身体验学习LLM 最好IDEA 工具

LobeChat LobeChat的开源&#xff0c;把AI功能集合到一起&#xff0c;真的太爽了。 我第一次发现LobeChat的时候&#xff0c;就是看到那炫酷的页面&#xff0c;这么强的前端真的是在秀肌肉啊&#xff01; 看下它的官网&#xff0c;整个网站的动效简直闪瞎我&#xff01; GitH…

【分子材料发现】——GAP:催化过程中吸附构型的多模态语言和图学习(数据集处理详解)(二)

Multimodal Language and Graph Learning of Adsorption Configuration in Catalysis https://arxiv.org/abs/2401.07408Paper Data: https://doi.org/10.6084/m9.figshare.27208356.v2 1 Dataset CatBERTa训练的文本字符串输入来源于Open Catalyst 2020 &#xff08;OC20…

[小白系列]Ubuntu安装教程-安装prometheus和Grafana

Docker安装prometheus 拉取镜像 docker pull prom/prometheus 配置文件prometheus.yml 在/data/prometheus/建立prometheus.yml配置文件。&#xff08;/data/prometheus/可根据自己需要调整&#xff09; global:scrape_interval: 15s # By default, scrape targets ev…

oracle之用户的相关操作

&#xff08;1&#xff09;创建用户(sys用户下操作) 简单创建用户如下&#xff1a; CREATE USER username IDENTIFIED BY password; 如果需要自定义更多的信息&#xff0c;如用户使用的表空间等&#xff0c;可以使用如下&#xff1a; CREATE USER mall IDENTIFIED BY 12345…

Jenkins环境一站式教程:从安装到配置,打造高效CI/CD流水线环境-Ubuntu 22.04.5 环境离线安装配置 Jenkins 2.479.1

文章目录 Jenkins环境一站式教程&#xff1a;从安装到配置&#xff0c;打造高效CI/CD流水线环境-Ubuntu 22.04.5 环境离线安装配置 Jenkins 2.479.1一、环境准备1.1 机器规划1.2 环境配置1.2.1 设置主机名1.2.2 停止和禁用防火墙1.2.3 更新系统 二、安装配置Jenkins2.1 安装JDK…

flinkSql 将流和表的互相转换

流——>表 方式一 方式二 方式一&#xff1a;写sql DataStreamSource<String> source env.socketTextStream("localhost", 8881); // 表名&#xff0c;流&#xff0c;字段名称 tableEnv.createTemporaryView("t_1",source&#xff0c;$("…

AI大模型驱动数据分析:利用自然语言实现数据查询与可视化(1)

在当今AI驱动的时代&#xff0c;数据分析已成为各行各业不可或缺的能力。然而&#xff0c;传统的数据分析流程通常需要掌握SQL、数据处理和可视化等多项专业技能&#xff0c;这对非技术背景的业务人员来说是一个不小的挑战。 想象一下&#xff0c;当数据中心的负责人打开手机时…

PyCharm+Selenium+Pytest配置小记

1、下载ChromeDriver&#xff1a; Chrome130以后的Driver下载&#xff1a; Chrome for Testing availabilityhttps://googlechromelabs.github.io/chrome-for-testing/ &#xff08;1&#xff09;查看自己Crome浏览器的版本&#xff1a;设置-->关于 Chrome&#xff1b; &…

【原生js案例】webApp实现鼠标移入移出相册放大缩小动画

图片相册这种动画效果也很常见&#xff0c;在我们的网站上。鼠标滑入放大图片&#xff0c;滑出就恢复原来的大小。现在我们使用运动定时器来实现这种滑动效果。 感兴趣的可以关注下我的系列课程【webApp之h5端实战】&#xff0c;里面有大量的css3动画效果制作原生知识分析&…

Qt 安装Qt Serial Port

最近要用Qt写个串口上位机软件&#xff0c;发现Qt的串口库用不了&#xff0c;上网找了一下资料&#xff0c;找到一种解决办法&#xff0c;具体操作如下&#xff1a; 参考文章&#xff1a;https 目录 一、找到QT安装路径&#xff0c;并运行Qt Maintenance Tool二、选择 添加或移…

语音识别flask接口开发

要开发一个flask语音识别接口&#xff0c;首先要解决语音文件在网络中的传输问题&#xff0c;然后选识别算法进行识别 文章目录 1、以二进制文件流方式上次语音2、网页端长连接流式上传语音文件3、语音识别接口 1、以二进制文件流方式上次语音 python服务端代码&#xff0c;以…

计算机毕业设计Python医疗问答系统 医疗可视化 BERT+LSTM+CRF深度学习识别模型 机器学习 深度学习 爬虫 知识图谱 人工智能 大数据毕业设计

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…

shell条件测试

一.命令执行结果判定 && 在命令执行后如果没有任何报错时会执行符号后面的动作 || 在命令执行后如果命令有报错会执行符号后的动作 示例&#xff1a; [rootqingdeng shell3]# sh sl.sh /mnt/file is not exist no二.条件判断方法 在 shell 程序中&#xff0c;用户可…

Couchbase Lite for Android 开源项目 FAQ

Couchbase Lite for Android 开源项目 FAQ couchbase-lite-android couchbase/couchbase-lite-android: Couchbase Lite for Android 是一个轻量级的嵌入式NoSQL数据库引擎&#xff0c;可以在Android设备上离线存储和处理数据&#xff0c;并支持与Couchbase Server进行同步&…

DVWA 靶场 SQL 注入报错 Illegal mix of collations for operation ‘UNION‘ 的解决方案

在 dvwa 靶场进行联合 SQL 注入时&#xff0c;遇到报错 Illegal mix of collations for operation UNION报错如下图&#xff1a; 解决办法&#xff1a; 找到文件MySQL.php 大致位置在dvwaincludesDBMS 目录下 使用编辑器打开 检索$create_db 第一个就是 在{$_DVWA[ ‘db_d…