一、Docker Compose 部署 GitLab
GitLab 是利用 Ruby on Rails 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面进行访问公开的或者私人项目。它拥有与 Github 类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊天程序 (Wall) 进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。
1、部署 GitLab
我们使用 Docker 来安装和运行 GitLab 中文版,docker-compose.yml
配置如下:
version: '3'
services:
gitlab:
image: 'twang2218/gitlab-ce-zh'
restart: always
container_name: 'gitlab'
privileged: true
hostname: 'gitlab'
environment:
TZ: 'Asia/Shanghai'
GITLAB_OMNIBUS_CONFIG: |
external_url 'http://192.168.152.204或者域名'
gitlab_rails['time_zone'] = 'Asia/Shanghai'
gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.163.com"
gitlab_rails['smtp_port'] = 465
gitlab_rails['smtp_user_name'] = "xxx@163.com"
gitlab_rails['smtp_password'] = "xxx"
gitlab_rails['smtp_domain'] = "163.com"
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['smtp_tls'] = true
gitlab_rails['gitlab_email_from'] = 'xxx@163.com'
gitlab_rails['gitlab_shell_ssh_port'] = 220
unicorn['port'] = 8888
nginx['listen_port'] = 80
ports:
- '8081:80'
- '443:443'
- '220:22'
volumes:
- /data/gitlab/config:/etc/gitlab
- /data/gitlab/data:/var/opt/gitlab
- /data/gitlab/logs:/var/log/gitlab
2、配置 GitLab
- 访问地址:http://ip:8081
-
设置管理员初始密码,这里的密码最好是 字母 + 数字组合,并且大于等于 8 位
-
配置完成后登录,管理员账号是 root
注意: 如果服务器配置较低,启动运行可能需要较长时间,请耐心等待
3、设置 GitLab
第一次使用时可以做一些初始化设置,点击 管理区域 -> 设置
- 关闭头像功能,由于 Gravatar 头像为网络头像,在网络情况不理想时可能导致访问时卡顿
- 由于是内部代码托管服务器,可以直接关闭注册功能,由管理员统一创建用户即可
4、账户管理
使用时请不要直接通过 root 用户操作,需要先创建用户,然后通过创建的用户操作,如果你是管理员还需要为其他开发人员分配账户
- 创建账户,点击 管理区域 -> 新建用户
- 设置账户信息,同时你可以将自己设置为管理员
- 修改用户密码,由于我们创建时并没有配置邮箱,所以还需要重新编辑用户信息并手动设置密码
- 退出并使用新账户登录
注意: 创建完账户,第一次登录时还会提示你修改登录密码
5、项目管理
- 点击 + 号 -> 新建项目
- 输入项目名称及描述信息,设置可见等级为私有,这样别人就看不见你的项目
-
我们选择通过增加一个 README 的方式来初始化项目
-
直接提交修改即可