OpenWebUI(20)源码学习-版本升级

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


OpenWebUI升级

提示:这里可以添加本文要记录的大概内容:

你的数据(聊天、用户、设置、上传,包括知识库等)存在于Docker卷或本地数据库中,而不是在容器中。更新Open webUI意味着将容器映像交换为新的容器映像。你的数据会留在原来的地方。


提示:以下是本篇文章正文内容,下面案例可供参考

一、备份数据

进入主机目录下,运行docker备份openwebui中的卷数据。

1. 首次安装

当我首次用docker安装的时候,一般执行的下面命令:

bash 复制代码
docker run -d -p 3000:8080 --add-host=host.docker.internal:host-gateway -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main

-v open-webui:/app/backend/data 将openwebui的所有产生的数据存储在docker容器中的位置:/app/backend/data ,对应映射到宿主机卷名:open-webui下(真实位置:/var/lib/docker/volumes/open-webui/_data)

docker内的后端数据默认存储在主机的/var/lib/docker/volumes/open-webui/_data目录下

2.升级前备份数据

需要将上面后端数据提前备份,万一升级失败,还可以用这些备份的数据回退到原来版本;给你的数据上个"双保险"

bash 复制代码
# 进入工作目录
cd  /home/jinhu/openwebui/update_backup
# 开始备份数据
docker run --rm -v open-webui:/data -v $(pwd):/backup \
  alpine tar czf /backup/openwebui-$(date +%Y%m%d).tar.gz /data

这个命令的意思是:启动一个临时的 Alpine 容器,把 open-webui 卷挂载到容器的 /data,把当前目录挂载到 /backup,然后在容器内把 /data 下的所有内容打包压缩成一个带日期的文件,存到 /backup 里

3.开始升级

(1)停止 并移除原来的容器

bash 复制代码
docker stop open-webui
docker rm open-webui

(2)拉取最新的 Docker 镜像

bash 复制代码
docker pull 192.168.11.103:5000/open-webui:v0.8.12-cuda

(3)使用相同的数据卷启动新容器

这一步最关键:启动命令必须和原来一样,确保新容器依然挂载 open-webui 这个卷。

bash 复制代码
docker run -d -p 3000:8080   -v open-webui:/app/backend/data  -e WEBUI_SECRET_KEY="sk-hinmu6688-2026"   --name open-webui --restart always  --gpus all   192.168.11.103:5000/open-webui:v0.8.12-cuda

4.验证

打开浏览器访问 http://localhost:3000

查看对应的用户,对话记录,知识库等是否正常显示

5.升级失败回退

如果发现升级失败,要回退

bash 复制代码
# 1. 停止并移除有问题的容器
docker stop open-webui
docker rm open-webui

# 2. 用备份文件恢复数据卷
docker run --rm -v open-webui:/data -v $(pwd):/backup alpine sh -c "rm -rf /data/* && tar xzf /backup/openwebui-backup-YYYYMMDD.tar.gz -C /data"

# 3. 使用旧版本镜像重新启动容器,回到升级前的状态
#    (将 latest 替换为你之前备份时使用的旧镜像标签)
docker run -d --name open-webui \
  -p 3000:8080 \
  -v open-webui:/app/backend/data \
  --restart unless-stopped \
  ghcr.io/open-webui/open-webui:[旧版本号]
相关推荐
冬奇Lab8 小时前
Agent 系列(23):Web Agent——让 Agent 真正浏览网页
人工智能·llm·agent
冬奇Lab9 小时前
每日一个开源项目(第135篇):codebase-memory-mcp - 给 AI Agent 一张代码库的知识图谱
人工智能·开源·llm
IT_陈寒11 小时前
JavaScript的闭包把我坑惨了,说好的内存会自动回收呢?
前端·人工智能·后端
哥布林学者14 小时前
深度学习进阶(三十一)FlashAttention:IO 感知的精确注意力
机器学习·ai
jooloo15 小时前
Codex 间歇性 400 之谜:一条对话里,它为什么有时候用 chat/completions,有时候切到 responses?
人工智能
用户51914958484515 小时前
OpenSSL PKCS#12 PBMAC1 堆栈缓冲区溢出漏洞 (CVE-2025-11187) 分析与验证
人工智能·aigc
用户51914958484516 小时前
HP Sound Research SECOMNService 权限提升漏洞利用工具
人工智能·aigc
用户0183493016916 小时前
给 AI 智能体能力包一层 BFF,前端只调一个接口
人工智能