GitLab Docker 镜像部署

环境说明

系统环境 macOS
docker
原文地址

部署需求


docker 安装是必须的,可参考docker安装指引

提示:若使用持久卷(the persisted volumes) ,建议安装原生的docker,而不是Docker Toolbox。

运行镜像


运行镜像


sudo 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

上述命令将下载并启动 GitLab CE 容器,对外访问端口 SSH、HTTP和HTTPS。所有
GitLab 数据将被存储在/srv/gitlab/ 这个目录下。该容器将在系统重启时自动重启。
现在,你可以通过web地址访问。

提示:如下是我自己测试时的运行命令

docker pull gitlab/gitlab-ce
docker run --detach \
--hostname gitlab.example.com \
--publish 8443:443 --publish 8080:80  \
--name gitlab \
--restart always \
--volume /Volumes/MacSoft/data/gitlab/config:/etc/gitlab \
--volume /Volumes/MacSoft/data/gitlab/logs:/var/log/gitlab \
--volume /Volumes/MacSoft/data/gitlab/data:/var/opt/gitlab \
gitlab/gitlab-ce:latest     
docker exec -it gitlab bash

如果你运行的系统打开了SELinux,则需要用如下命令

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:Z \
    --volume /srv/gitlab/logs:/var/log/gitlab:Z \
    --volume /srv/gitlab/data:/var/opt/gitlab:Z \
    gitlab/gitlab-ce:latest

这将确保Docker进程有足够的权限在被挂载的卷上去创建配置文件。

数据存储在哪?


本地位置 容器位置 描述
/srv/gitlab/data /var/opt/gitlab 存储应用数据
/srv/gitlab/logs /var/log/gitlab 存储日志
/srv/gitlab/config /etc/gitlab 存储GitLib 配置文件

你也可以微调这些目录,去满足你的需求。

配置GitLib


  • 这个容器使用的官方Omnibus GitLab 包,因此所有配置被设定在唯一的配置文件 /etc/gitlab/gitlab.rb

  • 你可以在一个运行中的容器环境下启动一个shell 回话,去访问GitLib 配置文件。这将允许你去访问所有的目录并使用你喜欢的编辑器去编辑他。

sudo docker exec -it gitlab /bin/bash

  • 你也可以直接编辑 /etc/gitlab/gitlab.rb

sudo docker exec -it gitlab vi /etc/gitlab/gitlab.rb
首先打开/etc/gitlab/gitlab.rb 确认设置参数 external_url指向了有效的URL

  • 若从GitLib 接收邮件,你必须配置SMTP setting 项,因为GitLib Docker 镜像没有安装 SMTP 服务。

  • 你也可能愿意 Enabling HTTPS。

所有的配置修改后,你需要重启容器,GitLab 配置才能生效。
sudo docker restart gitlab

提示:每次容器启动,GitLab会重置配置。更多的配置选项可以参考Omnibus GitLab 文档。

前置配置 Docker 容器


你可以前置配置GitLab Docker 镜像,在Docker 运行命令时通过添加 --env 参数 GITLAB_OMNIBUS_CONFIG。这个参数可以包括任意gitlab.rb 的设置,并将在加载容器内gitlab.rb文件前被生效。
通过这个方法,你可以很容易的配置GitLab的 external_url ,设置任意的数据库配置或其他Omnibus GitLab的配置选项。
提示:这个设置包括在GITLAB_OMNIBUS_CONFIG 参数下,配置内容不会写入gitlab.rb 中,仅在容器每次启动时被生效。
如下例子是当容器启动时设置外部URL 并打开LFS 支持。

sudo docker run --detach \
    --hostname gitlab.example.com \
    --env GITLAB_OMNIBUS_CONFIG="external_url 'http://my.domain.com/'; gitlab_rails['lfs_enabled'] = true;" \
    --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

提示: 每次执行“docker run” 命令,你都需要指定“GITLAB_OMNIBUS_CONFIG” 参数,这个参数的内容是不会在每次“docker run” 后存储的。
配置GitLab时,环境变量的数量也是有限制的。具体可参看GitLab 文档的环境变量章节。

启动容器后


启动容器后,你可以访问http://localhost 或 http://192.168.59.103 如果你用 boot2docker. 可能也需要等一段时间才能响应你的请求操作。

提示: 初始命令可能花费很长时间。你可以用“sudo docker logs -f gitlab ” 这个命令跟踪查看日志。当你第一次访问GitLab 时,你将被要求设置admin 密码。你设置密码后,就可以用用户名 root 和刚才设置的密码登陆了。

更新GitLab

运行GitLab CE 在一个外网IP


你可以将Docker 容器用你自己的IP地址,将docker 的所有流量都转发到 --publish 参数指定的IP 地址

sudo docker run --detach \
    --hostname gitlab.example.com \
    --publish 1.1.1.1:443:443 \
    --publish 1.1.1.1:80:80 \
    --publish 1.1.1.1: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

提示: 你可以通过http://1.1.1.1 或 https://1.1.1.1 访问GitLab

转发GitLab 到不同的端口


诊断潜在的问题


读取Docker 容器日志

sudo docker logs gitlab

进入运行中的容器

sudo docker exec -it gitlab /bin/bash

进入到容器内,你可以管理GitLab 容器

安装GitLab 用 docker-compose


利用 Docker compose 你可以很容易的配置、安装和升级GitLab 基础Docker
1、安装 Docker Compose
2、创建 docker-compose.yaml 文件(或下载一个样例)


web:
  image: 'gitlab/gitlab-ce:latest'
  restart: always
  hostname: 'gitlab.example.com'
  environment:
    GITLAB_OMNIBUS_CONFIG: |
      external_url 'https://gitlab.example.com'
      #Add any other gitlab.rb configuration here, each on its own line
  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'

3、确认你与docker-compose.yaml文件在同一目录,执行docker-compose up -d 启动GitLab

阅读“前置配置 Dokcer 容器”章节可以了解GITLAB_OMNIBUS_CONFIG 参数是如何工作的。
如下是 docker-compose.yaml 定义GitLab 运行在一个自定义 HTTP 和 SSH 端口的例子。注意,GITLAB_OMNIBUS_CONFIG 的参数内容可参见 ports 部分

web:
  image: 'gitlab/gitlab-ce:latest'
  restart: always
  hostname: 'gitlab.example.com'
  environment:
    GITLAB_OMNIBUS_CONFIG: |
      external_url 'http://gitlab.example.com:9090'
      gitlab_rails['gitlab_shell_ssh_port'] = 2224
  ports:
    - '9090:9090'
    - '2224:22'
  volumes:
    - '/srv/gitlab/config:/etc/gitlab'
    - '/srv/gitlab/logs:/var/log/gitlab'
    - '/srv/gitlab/data:/var/opt/gitlab'

这里同样使用 --publish 9090:9090 --publish 2224:22

更新 GitLab 用Docker compose


如果你安装 GitLab 用 docker-compose ,你可以运行 docker-compose pulldocker-compose up -d 去下载新的版本并更新你的GitLab 实例。

安装 GitLab 到一个集群


名词解析

持久卷(the persisted volumes):
https://www.cnblogs.com/leidaxia/p/6485646.html

转载于:https://blog.51cto.com/13673090/2096145

你可能感兴趣的:(GitLab Docker 镜像部署)