Skip to main content

📦 导出和导入数据库

如果您需要将 Open WebUI 数据(例如,聊天历史记录、配置等)从一台服务器迁移到另一台服务器或备份以备后用,您可以导出和导入数据库。本指南假设您使用内部 SQLite 数据库(而不是 PostgreSQL)运行 Open WebUI。

按照以下步骤导出和导入包含您的数据库的 webui.db 文件。


导出数据库

要从当前的 Open WebUI 实例导出数据库:

  1. 使用 docker cp 复制数据库文件
    webui.db 文件位于容器内的 /app/backend/data 目录中。运行以下命令将其复制到您的本地机器:

    docker cp open-webui:/app/backend/data/webui.db ./webui.db
  2. 将导出的文件传输到新服务器
    您可以使用 FileZilla 或您选择的任何其他文件传输工具将 webui.db 文件移动到新服务器。

    info

    推荐使用 FileZilla,因为它在传输文件到新服务器时易于使用。


导入数据库

webui.db 文件移动到新服务器后,按照以下步骤:

  1. 在新服务器上安装并运行 Open WebUI
    使用 Docker 容器设置并运行 Open WebUI。按照 🚀 快速开始 中提供的说明安装并启动 Open WebUI 容器。运行后,在执行导入步骤之前停止它。

    docker stop open-webui
  2. 使用 docker cp 将数据库文件复制到容器
    假设导出的 webui.db 文件在您当前的工作目录中,将其复制到容器中:

    docker cp ./webui.db open-webui:/app/backend/data/webui.db
  3. 启动 Open WebUI 容器
    再次启动容器以使用导入的数据库。

    docker start open-webui

    新服务器现在应该使用您导入的数据库运行 Open WebUI。


注意事项

  • 此导出/导入过程 仅在您使用内部 SQLite 数据库(webui.db)时有效
  • 如果您使用外部 PostgreSQL 数据库,此方法不适用,因为数据库在容器外部管理。对于 PostgreSQL,您需要遵循 PostgreSQL 特定的工具和程序来备份和恢复您的数据库。

为什么它很重要

此方法在以下情况下特别有用:

  • 将您的 Open WebUI 数据迁移到新服务器或机器。
  • 在更新或修改之前创建数据备份。
  • 在多个服务器上使用相同设置测试 Open WebUI。
# 导出和导入的快速命令摘要
# 导出:
docker cp open-webui:/app/backend/data/webui.db ./webui.db

# 在新服务器上停止容器:
docker stop open-webui

# 导入:
docker cp ./webui.db open-webui:/app/backend/data/webui.db

# 启动容器:
docker start open-webui

通过这些步骤,您可以轻松管理您的 Open WebUI 迁移或备份过程。请记住您使用的数据库格式以确保兼容性。