从旧版 Gitea 升级

在升级之前,您需要做如下的准备工作。

为重大变更检查更新日志

为了让 Gitea 变得更好,进行重大变更是不可避免的,尤其是一些里程碑更新的发布。 在更新前,请 在 Gitea 博客上阅读更新日志 并检查重大变更是否会影响你的 Gitea 实例。

在控制面板中检查过期的配置项

一些配置项可能会在后续版本中过期,你需要在控制面板中检查他们。如果不解决过期的配置项, Gitea也许会在升级后无法重启。你可以访问 https://docs.gitea.com 获得要升级的版本 对应的文档来修改你的配置文件。

降级前的备份

Gitea 会保留首二位版本号相同的版本的兼容性 (a.b.x -> a.b.y), 这些版本拥有相同的数据库结构,可以自由升级或降级。 其他情况 (a.b.? -> a.c.?)下, 新版 Gitea 可能将会将数据库升级到与旧版数据库不同的结构。

举个例子:

当前目标结果
1.4.01.4.1
1.4.11.4.0⚠️ 不建议,后果自负!尽管数据库结构可能不会变更,让它可以正常工作。我们强烈建议降级前进行完全的备份。
1.4.x1.5.y✅ 数据库会被自动升级。你可以直接从 1.4.x 升级到最新的 1.5.y。
1.5.y1.4.x❌ 数据库已被升级且无法用于旧版本Gitea,使用备份来进行降级。

因为你不能基于升级后的数据库运行旧版 Gitea,所以你应该在数据库升级前完成数据备份。

如果你在生产环境下使用 Gitea,你应该在升级前做好备份,哪怕只是小版本的补丁更新。

备份步骤:

  • 停止 Gitea 实例
  • 备份数据库
  • 备份 Gitea 配置文件
  • 备份 Gitea 在 APP_DATA_PATH 中的数据文件
  • 备份 Gitea 的外部存储 (例如: S3/MinIO 或被使用的其他存储)

如果你在使用云服务或拥有快照功能的文件系统, 最好对 Gitea 的数据盘及相关资料存储进行一次快照。

在所有上述步骤准备妥当之后,要升级 Gitea,只需要下载新版,停止运行旧版,进行数据备份,然后运行新版就好。 每次 Gitea 实例启动时,它都会检查是否要进行数据库迁移。 如果需要进行数据库迁移,Gitea 会花一些时间完成升级然后继续服务。

从 Docker 升级

  • docker pull 拉取 Gitea 的最新发布版。
  • 停止运行中的实例,备份数据。
  • 使用 dockerdocker-compose 启动较新的 Gitea Docker 容器.

从包升级

  • 停止运行中的实例,备份数据。
  • 使用你的包管理器更新 Gitea 到最新版本。
  • 启动 Gitea 实例。

从二进制升级

  • 下载最新的 Gitea 二进制文件到临时文件夹中。
  • 停止运行中的实例,备份数据。
  • 将旧的 Gitea 二进制文件覆盖成新的。
  • 启动 Gitea 实例。

在 Linux 系统上自动执行以上步骤的脚本可在 Gitea 的 source tree 中找到 contrib/upgrade.sh 来获取.

小心你的自定义模板

Gitea 的模板结构与变量可能会随着各个版本的发布发生变化,如果你使用了自定义模板, 你得注意你的模板与你使用的 Gitea 版本的兼容性。

如果自定义模板与 Gitea 版本不兼容,你可能会遇到: 50x 服务器错误,页面元素丢失或故障,莫名其妙的页面布局,等等… 移除或更新不兼容的模板,Gitea Web 才可以正常工作。