在 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 清理与部署流程。

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数字化招聘系统如何帮助企业实现招聘效率翻倍提升?

众所周知&#xff0c;传统的招聘方式已经难以满足现代企业对人才的需求&#xff0c;而数字化招聘系统的出现&#xff0c;为企业提供了全新的解决方案。通过数字化招聘系统&#xff0c;企业可以自动化处理繁琐的招聘流程&#xff0c;快速筛选合适的候选人&#xff0c;从而大幅提…

【Email】基于SpringBoot3.4.x集成发送邮件功能

【Email】基于SpringBoot3.4.x集成发送邮件功能 摘要本地开发环境说明pom.xml启动类application.yaml写一个邮件模板定义模板引擎工具类定义一个邮件发送对象封装一个邮件发送器单元测试邮件模板单元测试发送邮件单元测试 邮件效果参考资料 摘要 在业务系统开发过程中&#xf…

如何在小米平板5上运行 deepin 23 ?

deepin 23 加入了 ARM64 支持&#xff0c;这里尝试将 deepin 系统刷入平板中&#xff0c;平常使用中&#xff0c;带个笔记本电脑有时候也会嫌比较麻烦&#xff0c;把 Linux 系统刷入平板中既满足了使用需要&#xff0c;又满足了轻便的需求。为什么不使用 Termux &#xff1f;虽…

java+springboot+mysql在线文件管理系统

项目介绍&#xff1a; 使用javaspringbootmysql开发的在线文件管理系统&#xff0c;系统包含管理员、使用员、监察员角色&#xff0c;功能如下&#xff1a; 管理员&#xff1a;使用员管理&#xff1b;监测员管理&#xff1b;留言管理&#xff08;回复&#xff09;&#xff1b…

网站多语言前端翻译translate.js 在vue项目中的使用方法

网站多语言前端翻译translate.js 在vue项目中的使用方法 需求 客户网站&#xff0c;想要多语言版本的&#xff0c;通常的解决办法有两种&#xff1a; 1、最直接的办法&#xff1a;编写两种&#xff0c;或者多种语言版本的网站&#xff0c;也就是一个网站有几种语言&#xff0…

《Django 5 By Example》阅读笔记:p493-p520

《Django 5 By Example》学习第 17 天&#xff0c;p493-p520 总结&#xff0c;总计 28 页。 一、技术总结 1.internationalization(国际化) vs localization(本地化) (1)18n&#xff0c;L10n&#xff0c;g11n 以前总觉得这两个缩写好难记&#xff0c;今天仔细看了下维基百科…

mycat2读写分离配置

逻辑库配置 登录mycat 创建逻辑库&#xff0c;配置数据源 mycat2安装和使用 create database mycar_db1;修改mycar_db1.schema.json配置文件 指定的数据’targetName’&#xff1a;‘prototype’&#xff0c;配置主机数据源 targetName的参数可以是数据源 也可以是集群 这儿…

.Net 多线程、异步、性能优化应用与心得

文章目录 概要多线程Thread方式创建线程:Task方式创建线程[C#5.0引入]&#xff08;推荐使用&#xff09;:线程池方式创建线程&#xff1a; 异步异步方法异步IO操作异步数据库操作异步Web请求取消异步ValueTask[C# 7.0引入]ValueTask<TResult> 和 Task 性能优化懒加载对象…

如何在项目中使用人大金仓替换mysql

文章目录 数据库连接配置调整驱动和连接字符串修改&#xff1a;用户名和密码&#xff1a; SQL 语法兼容性检查数据类型差异处理&#xff1a;函数差异&#xff1a;SQL语句客户端 SQL 交互工具 数据迁移数据库、用户移植数据迁移工具使用&#xff1a;迁移过程中的问题及解决方案 …

Docker 安装 sentinel

Docker 安装系列 1、拉取 [rootTseng ~]# docker pull bladex/sentinel-dashboard Using default tag: latest latest: Pulling from bladex/sentinel-dashboard 4abcf2066143: Pull complete 1ec1e81da383: Pull complete 56bccb36a894: Pull complete 7cc80011dc6f: Pull…

十一、容器化 vs 虚拟化-Docker 使用

文章目录 前言一、Docker Hello World二、Docker 容器使用三、Docker 镜像使用四、Docker 容器连接五、Docker 仓库管理六、Docker Dockerfile七、Docker Compose八、Docker Machine九、Swarm 集群管理 前言 Docker 使用‌ Docker 容器使用、镜像使用、容器连接、仓库管理、Do…

【报错】新建springboot项目时缺少resource

1.问题描述 在新建springboot项目时缺少resources,刚刚新建时的目录刚好就是去掉涂鸦的resources后的目录 2.解决方法 步骤如下&#xff1a;【文件】--【项目结构】--【模块】--【源】--在main文件夹右击选择新建文件夹并命名为resources--在test文件夹右击选择新建文件夹并命名…

Java面试之Happens-Before原则

此篇接上一篇的Java面试之volatile关键字。 首先&#xff0c;这是Java语言中的一个“先行发生”(Happens-Before)的原则。是判断数据是否存在竞争&#xff0c;线程是否安全的非常有用的手段&#xff0c;也是Java内存模型中定义的两项操作之间的偏序关系。 其次&#xff0c;Happ…

AB plc设备数据 转 opc ua项目案例

目录 1 案例说明 2 VFBOX网关工作原理 3 准备工作 4 网关采集AB PLC数据 5 启动OPC UA协议转发采集的数据 6 案例总结 1 案例说明 设置网关采集AB PLC数据把采集的数据转成opc ua协议转发给其他系统。 2 VFBOX网关工作原理 VFBOX网关是协议转换网关&#xff0c;是把一种…

ASP.NET|日常开发中连接Sqlite数据库详解

ASP.NET&#xff5c;日常开发中连接Sqlite数据库详解 前言一、安装和引用相关库1.1 安装 SQLite 驱动1.2 引用命名空间 二、配置连接字符串2.1 连接字符串的基本格式 三、建立数据库连接3.1 创建连接对象并打开连接 四、执行数据库操作4.1 创建表&#xff08;以简单的用户表为例…

Redis篇-6--原理篇5--单线程模型

1、概述 Redis 采用单线程模型来处理客户端请求&#xff0c;这意味着在任意时刻只有一个命令被执行。这种设计简化了 Redis 的实现&#xff0c;并确保了高并发环境下的数据一致性。尽管 Redis 是单线程的&#xff0c;但它通过高效的内存管理和网络 I/O 操作&#xff0c;仍然能…

Spring Boot + Spring AI快速体验

Spring AI快速体验 1 什么是Spring AI主要功能 2 快速开始2.1 版本说明2.2 配置文件2.3 pom依赖2.3.1 spring maven仓库2.3.2 核心依赖 2.4 定义ChatClient2.5 启动类2.6 测试 3 参考链接 1 什么是Spring AI Spring AI是Spring的一个子项目&#xff0c;是Spring专门面向于AI的…

【Unity】【VR开发】摩托车游戏开发笔记1-摩托车手把旋转时轴位移问题

【背景】 做VR摩托车游戏时,需要给摩托车加仿真控制,其中就有抓握龙头旋转时转弯的实现。 实现分两部分,一个是视觉上的动画实现,一个是摩托车实际的位移控制实现。先实现动画效果,也就是抓握把手能够让车头左右旋转。这里先简单一点,实现左手单手让车头旋转。 【设计】…

uniapp -- 实现页面滚动触底加载数据

效果 首选,是在pages.json配置开启下拉刷新 {"path": "pages/my/document/officialDocument","style": {"navigationStyle":</

丹摩|丹摩助力selenium实现大麦网抢票

丹摩&#xff5c;丹摩助力selenium实现大麦网抢票 声明&#xff1a;非广告&#xff0c;为用户体验 1.引言 在人工智能飞速发展的今天&#xff0c;丹摩智算平台&#xff08;DAMODEL&#xff09;以其卓越的AI算力服务脱颖而出&#xff0c;为开发者提供了一个简化AI开发流程的强…