gitlab搭建

环境说明:
虚拟机 centos 7 64位
内存:4GB
存储:100GB
CPU: CORE

版本:
gitlab 10.0.3 

  • 配置系统基础环境

配置阿里巴巴 yum 源

wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

重建yum 的缓存

yum clean all

yum makecache

配置 yum 的本地源

mount ~/CentOS-7-x86_64-DVD-1708.iso /mnt/cdrom/

修改本地 yum 的配置

git clone https://gitlab.com/xhang/gitlab.git

将 baseurl 的参数增加一个列表

git clone https://gitlab.com/xhang/gitlab.git

修改enabled值,改为

enabled=1

  • 安装gitlab 环境准备

安装 git

yum install -y git

创建 gitlab汉化版的源码目录,等一下使用git clone 一份新的代码

mkdir gitlab_zh

cd gitlab_zh

git clone https://gitlab.com/xhang/gitlab.git

当前作者下载汉化源码为10.0.4,但是即将安装的 gitlab 版本为 10.0.3

  • 安装gitlab

安装 gitlab 的依赖包

yum install curl openssh-server openssh-clients postfix cronie policycoreutils-python –y

yum install -y patch

启动 postfix,并且设置为开机启动

systemctl start postfix

systemctl enable postfix

设置防火墙

firewall-cmd --add-service=http --permanent

firewall-cmd --reload

大家从网上下载好 gitlab 的rpm 包后,就可以安装了

rpm -i gitlab-ce-10.0.3-ce.0.el7.x86_64.rpm

gitlab 下载地址:

https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/

当 shell 中出现以下内容,则证明 gitlab 的程序安装完了

 

继续安装提示执行配置 gitlab 的命令

gitlab-ctl reconfigure

修改 gitlab 的配置文件

vi /etc/gitlab/gitlab.rb

修改里面的 external_url 参数,例如作者的机器的IP地址为 10.211.55.10

external_url='http://10.211.55.10'

因为修改了配置文件,所以重新加载配置文件

gitlab-ctl reconfigure

 

  • 汉化 gitlab

使用汉化包来为社区版本的 gitlab 打补丁

停止 gitlab 服务

gitlab-ctl stop

切换到 刚才从 github 上download 的汉化包目录

cd /root/source/gitlab_zh/gitlab/

找出安装的 10.0.3 版本和 汉化版本10.0.4 中的不同点

git diff v10.0.3 v10.0.4-zh > ../10.0.3-zh.diff

目录倒退一层

cd ../

将 10.0.3-zh.diff 的补丁添加到 gitlab 中

patch -d /opt/gitlab/embedded/service/gitlab-rails -p1 < 10.0.3-zh.diff

重新启动 gitlab 服务

gitlab-ctl start

重新配置 gitlab

gitlab-ctl reconfigure

软件安装部分就完成了,以下是web 页面配置部分

  • web页面配置

由于作者本机的IP 地址为 10.211.55.10,而且gitlab 默认的端口号为 80,所以使用浏览器访问以下地址:
http://10.211.55.10:80

 

 

用户自己在页面上输入 新的密码,该密码为 管理员密码

未来管理员的登陆名为 root,密码为刚才修改的密码

 

  • 配置gitlab 用户注册时的邮箱通知信息

修改 /etc/gitlab/gitlab.rb 配置文件,该邮箱地址是未来gitlab 向用户发送邮件时的推送邮箱

 

gitlab_rails['smtp_enable'] = true

gitlab_rails['smtp_address'] = "smtp.qq.com"           # 用户输入自己的smtp服务器地址,例如作者的时163 的企业服务地址

gitlab_rails['smtp_port'] = 25                         # 用户smtp 的端口号

gitlab_rails['smtp_user_name'] = "***@qq.com"          # 用户的邮箱地址

gitlab_rails['smtp_password'] = "PASSWORD"             # 用户的邮箱密码

gitlab_rails['smtp_domain'] = "qq.com"                 # 用户邮箱的域名

gitlab_rails['smtp_authentication'] = "login"

gitlab_rails['smtp_enable_starttls_auto'] = true

gitlab_rails['smtp_tls'] = false

gitlab_rails['gitlab_email_from'] = '***@qq.com'       # 用户的邮箱地址

user['git_user_email'] = "***@qq.com"                  # 用户的邮箱地址

 

作者在这里给大家一个提醒,如果大家安装gitlab 的环境为阿里云,一定要确认25 端口是否能够使用,作者就由于之后在阿里云上部署gitlab时,遇到25 端口无法使用的问题,所以一直导致在注册新用户时,邮件无法发送出去,这个时候解决方法可以选择使用打开 ssl 加密传输,这样端口就不再是 25 端口了,例如qq 的邮件配置应该变为

 

gitlab_rails['smtp_enable'] = true

gitlab_rails['smtp_address'] = "smtp.qq.com"           # 用户输入自己的smtp服务器地址,例如作者的时163 的企业服务地址

gitlab_rails['smtp_port'] = 465                        # 用户smtp 的端口号

gitlab_rails['smtp_user_name'] = "***@qq.com"          # 用户的邮箱地址

gitlab_rails['smtp_password'] = "PASSWORD"             # 用户的邮箱密码

gitlab_rails['smtp_domain'] = "qq.com"                 # 用户邮箱的域名

gitlab_rails['smtp_authentication'] = "login"

gitlab_rails['smtp_enable_starttls_auto'] = true

gitlab_rails['smtp_tls'] = false

gitlab_rails['gitlab_email_from'] = '***@qq.com'       # 用户的邮箱地址

user['git_user_email'] = "***@qq.com"                  # 用户的邮箱地址

gitlab_rails['smtp_tls'] = true                        # 打开 ssl 加密传输

 

 

因为修改了配置文件,所以重新加载配置文件

gitlab-ctl reconfigure

因为有时候邮箱的密码需要不定时修改,所以未来管理员也会同步修改登录邮箱的密码,在修改了配置文件后,所以在重新加载后,可以通过以下命令查看刚才修改的内容是否生效

gitlab-ctl show-config | grep smtp_password

 

管理员还需要在web的管理页面上修改对应的配置,管理员的配置页面可以点击以下按钮

 

 

gitlab是否打开新用户注册

 

 

如果管理员需要自己手工添加新用户可以在以下页面配置

 

 

 

其他的一些技术点

  • 查看gitlab 的配置

gitlab-ctl show-config

  • 查看gitlab 的运行日志

gitlab-ctl tail

  • 切换gitlab 仓库的数据目录

gitlab 默认的仓库数据目录为 /var/opt/gitlab/git-data/repositories/ ,如果未来用户的数据量大了,需要更换仓库数据目录,可以通过修改 /etc/gitlab/gitlab.rb 配置进行调整。

用户在调整gitlab 的配置之前,建议对其先停止服务。

gitlab-ctl stop

 然后用户创建好未来要迁移的数据目录,并且将原来的数据 迁移 过去,由于作者的 gitlab 是通过 rpm 包安装的,所以gitlab 的系统用户为 git,用户组为 root,所以在拷贝数据后还需要修改新数据目录的用户归属,否者后面gitlab 无法对该目录写入新的数据。

mkdir -p /mnt/gitlab/git-data/

mv /var/opt/gitlab/git-data/repositories/* /mnt/gitlab/git-data/repositories/

chown -R git:root /mnt/gitlab/git-data/*

然后用户就可以对 /etc/gitlab/gitlab.rb 进行调整了。

/etc/gitlab/gitlab.rb 默认对 数据目录 的配置是注释的。

 

 

用户可以新增配置信息

git_data_dirs({

  "default" => {

     "path" => "/mnt/gitlab/git-data"

  }

})

然后对 gitlab 重新刷新配置

gitlab-ctl reconfigure

重启 gitlab 服务

gitlab-ctl restart

  •  修改gitlab 的nginx服务端口号

 首先还是需要先关闭gitlab的服务

gitlab-ctl stop

修改 /etc/gitlab/gitlab.rb 文件(作者是在root 用户下直接修改的)

找到以下内容(作者对应是859行),修改为 nginx['listen_port'] = 8080

##! **Override only if you use a reverse proxy**

##! Docs: https://docs.gitlab.com/omnibus/settings/nginx.html#setting-the-nginx-listen-port

# nginx['listen_port'] = nil

同时还需要在 /etc/gitlab/gitlab.rb 文件 找到以下内容(作者对应的是 587 行),将 unicorn['port'] 设置为 8082(因为8080 端口已经被占用了)

### Advanced settings

# unicorn['listen'] = '127.0.0.1'

# unicorn['port'] = 8080

修改后的内容变为

### Advanced settings

# unicorn['listen'] = '127.0.0.1'

unicorn['port'] = 8082

用户还需要在 /var/opt/gitlab/gitlab-rails/etc/unicorn.rb 文件上找到以下内容(作者对应是 第7行 ),将listen 的端口设置为 8082

# What ports/sockets to listen on, and what options for them.

listen "127.0.0.1:8080", :tcp_nopush => true

修改后的内容变为

# What ports/sockets to listen on, and what options for them.

listen "127.0.0.1:8082", :tcp_nopush => true

更新gitlab 的配置

gitlab-ctl reconfigure

用户在 /var/opt/gitlab/nginx/conf/gitlab-http.conf 文件中,找到以下内容(作者对应是38行),将原来默认的的listen *:80 会被刷新为修改后的8080 (nginx 的端口就变为 8080)

 

upstream gitlab-workhorse {

  server unix:/var/opt/gitlab/gitlab-workhorse/socket;

}

 

 

server {

  listen *:8080;

 

重启 gitlab 服务

gitlab-ctl restart

这里用户一定要注意,如果直接修改 /var/opt/gitlab/nginx/conf/gitlab-http.conf 文件的 内容,则在执行 gitlab-ctl reconfigure 后,修改值会被覆盖

posted @ 2019-04-18 11:05  MakemoneytobuyModely  阅读(143)  评论(0编辑  收藏  举报