设为首页 收藏本站
查看: 902|回复: 0

[经验分享] GitLab Docker 镜像部署

[复制链接]

尚未签到

发表于 2018-5-26 06:48:59 | 显示全部楼层 |阅读模式
环境说明
  系统环境 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 pull 和 docker-compose up -d 去下载新的版本并更新你的GitLab 实例。

安装 GitLab 到一个集群

  略

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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-481102-1-1.html 上篇帖子: docker仓库管理,数据管理 下篇帖子: Docker 源码架构部署篇
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表