使用 Docker 容器备份与 Docker Compose 升级 GitLab 实例教程

在生产环境中运行 GitLab 时,备份与升级是保障安全与稳定的核心操作。下面我将结合官方文档与实践经验,整理出一份完整的教程。


🛠 前提条件

  • 已安装 Docker Engine 与 Docker Compose
  • GitLab 通过 Docker Compose 部署
  • 具备服务器的 root/sudo 权限
  • 熟悉基本的 Linux 命令行操作

📦 第一步:创建备份

在升级前,必须先备份数据与配置。

  • 完整备份

    bash 复制代码
    docker exec -t <container name> gitlab-backup create

    备份文件会写入:

    复制代码
    /var/opt/gitlab/backups
  • 数据库轻量备份(仅数据库,便于快速回滚)

    bash 复制代码
    docker exec -t <container name> gitlab-backup create SKIP=artifacts,repositories,registry,uploads,builds,pages,lfs,packages,terraform_state
  • secrets 文件备份

    • 容器内路径:/etc/gitlab/gitlab-secrets.json
    • 宿主机挂载路径:$GITLAB_HOME/config/gitlab-secrets.json
      该文件必须保存,否则恢复时会遇到密钥不一致问题。

📝 第二步:编辑 docker-compose.yml

docker-compose.yml 中更新 GitLab 镜像版本,例如:

yaml 复制代码
services:
  gitlab:
    image: gitlab/gitlab-ce:18.7.0-ce.0
    restart: always
    hostname: 'gitlab.example.com'
    ports:
      - '80:80'
      - '443:443'
      - '22:22'
    volumes:
      - /srv/gitlab/config:/etc/gitlab
      - /srv/gitlab/logs:/var/log/gitlab
      - /srv/gitlab/data:/var/opt/gitlab

镜像版本可在 Docker Hub GitLab 镜像库 查询。


🔄 第三步:拉取并升级

执行以下命令:

bash 复制代码
docker compose pull
docker compose up -d

这会拉取最新镜像并重启容器,挂载卷中的数据与配置会被保留。


✅ 第四步:验证升级

  • 查看容器状态:

    bash 复制代码
    docker compose ps
  • 检查日志:

    bash 复制代码
    docker compose logs -f gitlab
  • 登录 GitLab Web 界面,确认版本已更新。


⚠️ 注意事项

  • 版本跨度大时,建议分阶段升级(例如 15.x → 16.x)。
  • 升级失败时,可利用备份进行回滚。
  • 建议在 测试环境先验证升级流程,再应用到生产环境。

🎯 总结

升级流程核心步骤:

  • 创建备份(数据库 + secrets)
  • 编辑 docker-compose.yml 更新镜像版本
  • 执行 docker compose pull/up 完成升级
  • 验证升级结果 确认服务正常
相关推荐
cuijiecheng20182 小时前
GitLab创建项目
gitlab
啦啦啦小石头3 小时前
Docker 换源
docker
等什么君!5 小时前
docker -数据卷技术
运维·docker·容器
上天_去_做颗惺星 EVE_BLUE6 小时前
Docker高效使用指南:从基础到实战模板
开发语言·ubuntu·docker·容器·mac·虚拟环境
好好沉淀8 小时前
Docker开发笔记(详解)
运维·docker·容器
禅口魔心9 小时前
Win10 + WSL2 + Docker:K510(DongshanPI-Vision)开发环境从踩坑到跑通全记录(交叉编译 + 上板运行)
docker·嵌入式开发·wsl2·k510
Free Tester10 小时前
基于已有容器生成Dockerfile
docker
lcx_defender11 小时前
【Docker】Docker部署运行nacos
运维·docker·容器
啦啦啦小石头11 小时前
docker添加用户权限不使用sudo
运维·docker·容器
cuber膜拜11 小时前
Weaviate 简介与基本使用
数据库·python·docker·向量数据库·weaviate