一.安装并配置必要的依赖关系

首先要在CentOS系统上面安装所需的依赖:ssh、防火墙、postfix(用于邮件通知)、wegt,以下这些命令也会打开系统防火墙中的HTTP和SSH端口访问。

1.安装SSH协议

安装命令:sudo yum install -y curl policycoreutils-python openssh-server

出现如下图,表示安装成功

2.设置SSH服务开机自启动 

安装命令:sudo systemctl enable sshd

3.启动SSH服务

启动命令:sudo systemctl start sshd

4.安装防火墙                                                                                                      

安装命令:yum install firewalld systemd -y

出现如下图所示,表示安装成功

5.开启防火墙

开启命令:service firewalld  start

6.添加HTTP服务到firewalld

安装命令:sudo firewall-cmd --permanent --add-service=http

注:pemmanent表示永久生效,若不加--permanent系统下次启动后就会失效

7.重启防火墙

重启命令:sudo systemctl reload firewalld

8.安装Postfix邮件服务

安装命令:sudo yum install postfix

9.将postfix服务设置成开机自启动

命令:sudo systemctl enable postfix

10.启动postfix

启动命令:sudo systemctl start postfix

11.安装wget,用于从外网上下载插件

安装命令:sudo  yum -y install wget

如出现下图所示,表示安装成功

12.安装vim编辑器

安装命令:sudo yum install vim -y

如出现下图所示,表示安装 成功

二开始gitlab安装启动

1.配置yum源

vim /etc/yum.repos.d/gitlab-ce.repo

复制以下内容:

[gitlab-ce]
 name=Gitlab CE Repository
 baseurl=https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el$releasever/
 gpgcheck=0
 enabled=1

2.更新本地yum缓存

yum makecache

yum安装 ssh:Failed to download metadata for repo 'AppStream'

yun install openssh openssh-server openssh-clients

3.安装GitLab社区版

yum install gitlab-ce #自动安装最新版本

注:若需安装指定版本,则添加版本号即可,即yum install gitlab-ce-x.x.x

4.开启GitLab

gitlab-ctl start

GitLab常用命令

gitlab-ctl start # 启动所有 gitlab 组件;

gitlab-ctl stop # 停止所有 gitlab 组件;

gitlab-ctl restart # 重启所有 gitlab 组件;

gitlab-ctl status # 查看服务状态;

gitlab-ctl reconfigure # 启动服务;(重新加载配置文件,在GitLab初次安装后可以使用,但是在业务环境中不可随意使用,reconfigure会把一些过去的config还原,导致修改的端口以及域名等都没有了。)

vim /etc/gitlab/gitlab.rb # 修改默认的配置文件;

gitlab-rake gitlab:check SANITIZE=true --trace # 检查gitlab;

sudo gitlab-ctl tail # 查看日志;

三gitlab使用

1.登录GitLab

在浏览器的地址栏中输入服务器的公网IP即可显示GitLab的界面。首次登录会强制用户修改密码。密码修改成功后,输入用户名和密码进行登录。

注:若无法访问,则可以使用ps -ef命令查看服务是否正常启动,若未启动, 则重新开启,若仍然启动不了,则可使用gitlab-ctl reconfigure(仅限初始环境下使用)命令启动服务, 然后再访问GitLab。

2.创建Project

登录成功后会出现如下页面:

 

3.修改域名

由于没有DNS服务器,无法进行域名解析,所以需要将域名修改为主机名,进入终端修改一下文件即可。

vim /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml
  ## GitLab settings
  
   gitlab:
  
     ## Web server settings (note: host is the FQDN, do not include http://)
  
     host: 10.0.0.210
  
     port: 8888
  
     https: false


重启GitLab

gitlab-ctl restart

刷新GitLab页面查看是否修改成功

 

四gitlab的备份与恢复

 

1、gitlab创建备份

gitlab-rake gitlab:backup:create

使用以上命令会默认在/var/opt/gitlab/backups目录下创建一个名称类似为1520580592_2018_03_09_10.5.3_gitlab_backup.tar的压缩包, 这个压缩包就是Gitlab整个的完整部分, 其中开头的1520580592_2018_03_09_10.5.3是备份创建的日期。

2.删除project

点击创建的project页面下方的“Remove project”按钮,删除project。

此时已无project

3.GitLab恢复

停止相关数据连接服务

gitlab-ctl stop unicorn

gitlab-ctl stop sidekiq

从1520580592_2018_03_09_10.5.3编号备份中恢复

gitlab-rake gitlab:backup:restore BACKUP=1520580592_2018_03_09_10.5.3

启动Gitlab

gitlab-ctl start

4.查看GitLab页面中是否恢复project。

Gitlab 修改备份文件默认目录
可以通过修改/etc/gitlab/gitlab.rb来修改默认存放备份文件的目录。

 vim /etc/gitlab/gitlab.rb

gitlab_rails['backup_path'] = "/mnt/gitlab/backup" >>修改文件路径即可
修改完成之后使用gitlab-ctl reconfigure命令重载配置文件即可。

注意:因为涉及到重新加载配置,reconfigure会把一些过去的config还原,导致修改的端口以及域名等都没有了。建议在服务安装之后即修改仓库默认路径,若后期业务中修改此项,会对业务造成一定的影响。若后期业务需修改此项,请提前做好准备,然后再修改配置文件中的相应参数。

重载配置文件之后会发现/mnt/gitlab/backup的权限发生变化

五修改仓库的默认路径

1、修改配置文件,找到git_data_dirs

vim /etc/gitlab/gitlab.rb
# git_data_dirs({
 #   "default" => {
 #     "path" => "/mnt/nfs-01/git-data"
 #    }
 # })
 git_data_dir "/data/gitlab"   >>此处添加自定义的仓库路径,目录需提前创建


在git_data_dir下面添加一句git_data_dir "/data/gitlab"

2.停止当前gitlab,重新加载配置

注意:仓库路径的修改会导致已有project的丢失,请提前进行备份,具体备份操作请参考上文“GitLab的备份与恢复”,然后再修改配置文件中的相应参数。

gitlab-ctl stop

gitlab-ctl reconfigure

3.重新加载后,会发现在/data/gitlab目录下多出一个repositories目录

4.最后启动gitlab即可

gitlab-ctl start

GitLab服务端口修改
yum方式安装的GitLab的配置文件路径为/var/opt/gitlab/nginx/conf(其他安装方式的配置文件路径不一定相同,请自行查找)。

1、修改配置文件

vim /var/opt/gitlab/nginx/conf/gitlab-http.conf
###################################
 ##         configuration         ##
 ###################################
  
 upstream gitlab-workhorse {
   server unix:/var/opt/gitlab/gitlab-workhorse/socket;
 }
 server {
   listen *:8888;   >> 此处修改端口即可


2、重启服务

gitlab-ctl restart

3.访问ip:port,查看页面是否正常

注意1:端口修改之后,project中的IP也需要相应的修改,请参考上文“修改域名”,修改port参数即可。

注意2:执行gitlab-ctl reconfigure命令后,配置文件会重新加载,服务端口会重新恢复为默认端口80,所以,如需修改端口,请在上述两个步骤之后进行操作。

Gitlab部署中注意端口不要冲突。

      

3.修改gitlab配置文件指定服务器ip和自定义端口:

编辑命令:vim  /etc/gitlab/gitlab.rb

然后进行编辑,输入小写的字母'i',变成编辑模式,可编辑,按esc退出编辑模式进入命令行模式,然后进行:wq 或者:q!命令,

注 :     :wq(保存自己插入的数据并退出)    :q!(不保存并退出)     

如果编辑的时候出现下图,说明你退出的时候没有正常保存退出,那么你可以按照它的提示进行删除命令

命令 : rm /etc/gitlab/.gitlab.rb.swp(删除此文件)

4.讲自己的端口(这儿我是9999)添加到防火墙中

添加命令: firewall-cmd --zone=public --add-port=9999/tcp --permanent 

我这儿已经添加过了 有个warning 0

5.重启防火墙

重启命令:sudo systemctl reload firewalld

6.重置gitlab配置

重置命令:gitlab-ctl reconfigure 

重置的时候比较慢,可能几分钟 可能十几分钟 

如出现以下的界面表示重置成功

7.启动gitlab

启动命令:gitlab-ctl restart

如出现下图,表示安装成功

8.以为大功告成了,可以访问自己的gitlab了,结果访问gitlab 502 页面

简单翻译一下  gitlab服务器出席问题502-Whoops, GitLab is taking too much time to respond。
1.解决方式一:加大相应等待时间。
修改gitlab.rb文件

root@chenrui:/etc/gitlab# vim /etc/gitlab/gitlab.rb


在gitlab.rb中添加

unicorn['worker_processes'] = 3
 unicorn['worker_timeout'] = 60

然后进行重置下gitlab

重置命令sudo gitlab-ctl reconfigure

2.反正我进行第一步访问还是访问502

内存不足(最小2G),改完自己的虚拟机内存大小,重启虚拟机,再启动gitlab

发现访问还是502

3.我们可以使用命令 free -m 查看下内存的情况

发现自己的free一直在减少,used一直上涨,说明我们的gitlab还在启动,消耗内存中,所以我们现在去访问的时候就是502了,等待free不动 我们再去访问.那么就没问题了,一进去需要我们改自己的密码,gitlab初始账号是root,密码八位数,自己去设定吧.