1. 安装部署

1.1下载镜像

docker pull gitlab/gitlab-ce

1.2 运行GitLab容器

docker run --detach \
           --publish 8443:443 \
           --publish 8480:80 \
           --publish 2222:22 \
           --name gitlab \
           gitlab/gitlab-ce:latest

1.3 拷贝配置文件

docker cp  gitlab:/etc/gitlab/ /opt/gitlab/config/

1.4 修改gitlab配置

vim /opt/gitlab/config/gitlab.rb

1.修改邮箱配置:

### Email Settings
gitlab_rails['gitlab_email_enabled'] = true
gitlab_rails['gitlab_email_from'] = 'xxx@163.com'
gitlab_rails['gitlab_email_display_name'] = 'zlt'

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'] = "客户端授权密码"
gitlab_rails['smtp_domain'] = "smtp.163.com"
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['smtp_tls'] = true

2.设置外部url

external_url 'http://192.168.28.134:8480'

3.如果ssh端口不是22需要修改端口配置

gitlab_rails['gitlab_shell_ssh_port'] = 2222

1.5 创建启动文件

vim start.sh
#!/bin/bash
GITLAB_DIR=/opt/gitlab
docker stop gitlab
docker rm gitlab
docker run -d \
    -p 8443:443 -p 8480:8480 -p 2222:22 \
    --name gitlab \
    -v ${GITLAB_DIR}/config:/etc/gitlab \
    -v ${GITLAB_DIR}/logs:/var/log/gitlab \
    -v ${GITLAB_DIR}/data:/var/opt/gitlab \
    --privileged=true \
    gitlab/gitlab-ce:latest

修改HOST_NAME为自己喜欢的名字
GITLAB_DIR为挂载目录要修改为自己的目录

重新启动容器

sh start.sh

2. 免密访问

在gitlab里面添加了ssh key之后,以后本地pull/push就不需要登录了

2.1 获取本地客户端机器的公钥

1.先看看是不是已经有了,如果有内容就直接copy贴过去

cat ~/.ssh/id_rsa.pub

2.如果上一步没有这个文件我们就创建一个,运行下面命令生成(邮箱改成自己的),一路回车就好了

ssh-keygen -t rsa -C "youremail@example.com"

cat ~/.ssh/id_rsa.pub

3.复制公钥内容
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目

2.2 添加ssh key

1.打开ssh key页面Settings -> SSH Keys:
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_02
2.将上面第一步复制的公钥内容粘贴到里面点击Add key
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_03

3. webhook配置

  • webhoo是一种web回调或者http的push API,是向APP或者其他应用提供实时信息的一种方式。
  • 一般是需要通过git的某些行为触发jenkins构建使用
  • 如果只需要手动构建的话可以忽略webhook

3.1 配置触发

1.打开webhoo页面项目详情页面 -> Settings ->Integrations:
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_04
2.URL为jenkins的job构建地址加token参数

3.jenkins的token配置如下图
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_05
4.Trigger为触发的行为,默认是Push操作

5.增加webhook
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_06
6.可以通过test按钮测试触发器

3.2 webhook报错 Requests to the local network are not allowed

原因是gitlab 10.6 版本以后为了安全,不允许向本地网络发送webhook请求,如果想向本地网络发送webhook请求,则需要使用管理员帐号登录,默认管理员帐号是admin@example.com,密码就是你gitlab搭建好之后第一次输入的密码,登录之后, 点击Configure Gitlab ,如下图所示:
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_07
即可进入Admin area,在Admin area中,在settings标签下面,找到OutBound Request,勾选上Allow requests to the local network from hooks and services ,保存更改即可解决问题:
微服务轮子项目(44) -GitLab代码仓库_# 微服务轮子项目_08