Docker 中的GitLab备份、升级和迁移

Docker 中安装的 GitLab 怎么进行备份?

1. 备份和升级

1.1. 备份当前GitLab实例

输入备份指令对数据进行备份

如果有必要请将备份生成的文件 1723711757_2024_08_15_16.4.1_gitlab_backup.tar 复制到安全地址

docker exec -t <container name> gitlab-backup create

手动备份配置文件

/etc/gitlab/gitlab-secrets.json
/etc/gitlab/gitlab.rb

1.1.1. 停止并移除当前的GitLab容器

停止当前运行的GitLab容器:

docker stop gitlab

移除容器(移除容器不会删除数据卷):

docker rm gitlab

要在Docker中更新GitLab,你可以按照以下步骤操作:

1.1.2. 备份当前GitLab实例

在进行更新之前,建议先备份GitLab的数据和配置,以防出现问题时可以恢复到原来的状态。

bash
Copy code
docker exec -t gitlab gitlab-backup create

将生成的备份文件保存到安全的位置:

bash
Copy code
docker cp gitlab:/var/opt/gitlab/backups ./gitlab_backups/

1.1.3. 停止并移除当前的GitLab容器

停止当前运行的GitLab容器:

bash
Copy code
docker stop gitlab

移除容器(移除容器不会删除数据卷):

bash
Copy code
docker rm gitlab

1.2. 安装新版本的 GitLab

1.2.1. 拉取新的GitLab镜像

根据你想要更新到的版本,拉取新的GitLab镜像。例如,要更新到17.2.2:

docker pull gitlab/gitlab-ce
docker pull gitlab/gitlab-ce:17.2.2-ce.0

⚠️ 国内的 docker 被禁止访问了,现在从 docker 拉取镜像必须要使用 Proxy

1.2.2. 部署 Gitlab 镜像

命令行部署可查看运行日志,所以更推荐使用命令行部署

It seems you are upgrading from 16.4.1 to 17.3.0.
It is required to upgrade to the latest 16.11.x version first before proceeding.
Please follow the upgrade documentation at https://docs.gitlab.com/ee/update/index.html #upgrading-to-a-new-major-version

⚠️ 升级的版本跨度太大,需要逐级升级

It seems you are upgrading from 16.4.1 to 16.11.7.
It is required to upgrade to the latest 16.7.x version first before proceeding.
Please follow the upgrade documentation at https://docs.gitlab.com/ee/update/#upgrade-paths
  • 升级到gitlab-ce:16.7.6-ce.0
# remove
docker rm gitlab

# pull
docker pull gitlab/gitlab-ce:16.7.6-ce.0

# run
docker run \
  --publish 9443:443 \
  --publish 9080:80 \
  --publish 9022:22 \
  --name gitlab \
  --privileged=true \
  --volume /volume3/docker/gitlab/config:/etc/gitlab \
  --volume /volume3/docker/gitlab/logs:/var/log/gitlab \
  --volume /volume3/docker/gitlab/data:/var/opt/gitlab \
  gitlab/gitlab-ce:16.7.6-ce.0

💡 Gitlab 升级需要花费大量时间迁移和验证数据,需要等待约 20 分钟

  • 升级到gitlab/gitlab-ce:16.11.7-ce.0
# remove
docker rm gitlab

# pull
docker pull gitlab/gitlab-ce:16.7.6-ce.0

# run
docker run \
  --publish 9443:443 \
  --publish 9080:80 \
  --publish 9022:22 \
  --name gitlab \
  --privileged=true \
  --volume /volume3/docker/gitlab/config:/etc/gitlab \
  --volume /volume3/docker/gitlab/logs:/var/log/gitlab \
  --volume /volume3/docker/gitlab/data:/var/opt/gitlab \
  gitlab/gitlab-ce:16.11.7-ce.0

💡 确保 Gitlab 正常运行后,可在命令行运行时添加 --detach 指令让镜像运行于后台

  • 升级到gitlab/gitlab-ce:17.2.2-ce.0
# remove
docker rm gitlab

# pull
docker pull gitlab/gitlab-ce:17.2.2-ce.0

# run
docker run \
  --publish 9443:443 \
  --publish 9080:80 \
  --publish 9022:22 \
  --user 1026:100 \
  --name gitlab \
  --privileged=true \
  --volume /volume3/docker/gitlab/config:/etc/gitlab \
  --volume /volume3/docker/gitlab/logs:/var/log/gitlab \
  --volume /volume3/docker/gitlab/data:/var/opt/gitlab \
  gitlab/gitlab-ce:17.2.2-ce.0

1.2.3. 更新完成

截止 2024-08-22 11:45:27 已成功更新到 Gitlab latest 版本

docker run \
  --publish 9443:443 \
  --publish 9080:80 \
  --publish 9022:22 \
  --name gitlab \
  --privileged=true \
  --volume /volume3/docker/gitlab/config:/etc/gitlab \
  --volume /volume3/docker/gitlab/logs:/var/log/gitlab \
  --volume /volume3/docker/gitlab/data:/var/opt/gitlab \
  gitlab/gitlab-ce

    --user 1026:100 \

2. Docker Gitlab 迁移

2.1. 停止 Gitlab 并迁移数据

# stop gitlab
docker stop gitlab

# cp data files from the old server
scp -r root@192.168.0.53:/volume3/docker/gitlab/config ./
scp -r root@192.168.0.53:/volume3/docker/gitlab/data ./
scp -r root@192.168.0.53:/volume3/docker/gitlab/logs ./

2.2. 启动容器

2.2.1. 准备 docker-compose.yml

准备和原容器一模一样的 docker-compose.yml

version: '3.8'

services:
  gitlab:
    image: gitlab/gitlab-ce:17.3.0-ce.0
    container_name: gitlab
    privileged: true
    restart: always
    healthcheck:
      disable: true
    ports:
      - "9443:443"
      - "9080:80"
      - "9022:22"
    volumes:
      - /volume1/docker/gitlab_docker_transfer/config:/etc/gitlab
      - /volume1/docker/gitlab_docker_transfer/logs:/var/log/gitlab
      - /volume1/docker/gitlab_docker_transfer/data:/var/opt/gitlab

2.2.2. 启动服务

docker-compose up -d
  • ⚠️如果启动失败,大概率是文件夹权限不够
  • 💡解决方法:修改 data文件夹权限为全 0777 全读写
  • 0777 代表:
    • 所有者:读取、写入、执行(7)
    • 组用户:读取、写入、执行(7)
    • 其他用户:读取、写入、执行(7)
sudo chmod -R 0777 data
  • ✅修改完成后,可正常启动
### 如何在 Docker升级 GitLab #### 准备工作 为了确保顺利升级,在执行任何操作之前,建议备份现有数据。这可以通过停止当前容器并将卷中的数据复制到安全位置来完成[^1]。 ```bash docker stop gitlab_container_name docker cp gitlab_container_name:/var/opt/gitlab /path/to/safe/location/ ``` #### 停止旧版本的服务 在开始升级过程前,先要停止正在运行的老版本GitLab实例: ```bash docker stop gitlab_container_name docker rm gitlab_container_name ``` #### 下载新版本镜像 接着拉取最新的官方GitLab Docker镜像,这里假设目标是最新的稳定版: ```bash docker pull gitlab/gitlab-ce:latest ``` #### 启动新版服务并迁移数据 利用先前保存的数据重新启动GitLab容器,并指定挂载点以便恢复原有配置数据库状态: ```bash docker run --detach \ --hostname gitlab.example.com \ --publish 443:443 --publish 80:80 --publish 22:22 \ --name gitlab \ --restart always \ --volume /srv/gitlab/config:/etc/gitlab \ --volume /srv/gitlab/logs:/var/log/gitlab \ --volume /srv/gitlab/data:/var/opt/gitlab \ gitlab/gitlab-ce:latest ``` 上述命令会读取`/srv/gitlab/config`目录下的设置文件来进行初始化;如果这是首次安装,则该路径下应为空或仅含默认配置。 #### 验证更新成功 最后一步是验证升级后的GitLab是否正常运作。打开浏览器访问设定好的主机名(本例中为`gitlab.example.com`),确认界面显示无误且功能完好即可认为升级顺利完成。 #### 清理过期资源 一旦确认一切运转良好,可以选择删除不再使用的旧版本镜像以释放空间: ```bash docker image prune -f ``` 此命令将移除所有悬空(dangling)镜像——即那些未被任何容器引用的中间层图像。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值