一、前言

GitLab是利用 Ruby on Rails 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面进行访问公开的或者私人项目。

它拥有与 Github 类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。

团队成员可以利用内置的简单聊天程序(Wall)进行交流。

它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。

1、Git的家族成员

  • Git:是一种版本控制系统,是一个命令,是一种工具。
  • Gitlib:是用于实现Git功能的开发库。
  • Github:是一个基于Git实现的在线代码托管仓库,包含一个网站界面,向互联网开放。
  • GitLab:是一个基于Git实现的在线代码仓库托管软件,你可以用gitlab自己搭建一个类似于Github一样的系统,一般用于在企业、学校等内部网络搭建git私服。

2、Gitlab的服务构成

  • Nginx:静态web服务器。
  • gitlab-shell:用于处理Git命令和修改authorized keys列表。
  • gitlab-workhorse:轻量级的反向代理服务器。
  • logrotate:日志文件管理工具。
  • postgresql:数据库。
  • redis:缓存数据库。
  • sidekiq:用于在后台执行队列任务(异步执行)。
  • unicorn:An HTTP server for Rack applications,GitLab Rails应用是托管在这个服务器上面的。
    版本管理 GitLab 的安装及管理 (CentOS 7)
    版本管理 GitLab 的安装及管理 (CentOS 7)GitLab

3、GitLab工作流程

版本管理 GitLab 的安装及管理 (CentOS 7)
版本管理 GitLab 的安装及管理 (CentOS 7)GitLab

4、GitLab Shell

GitLab Shell有两个作用:为GitLab处理Git命令、修改authorized keys列表。

当通过SSH访问GitLab Server时,GitLab Shell会限制执行预定义好的Git命令(git push, git pull, git annex),调用GitLab Rails API 检查权限,执行pre-receive钩子(在GitLab企业版中叫做Git钩子),执行你请求的动作 处理GitLab的post-receive动作,处理自定义的post-receive动作。

当通过http(s)访问GitLab Server时,工作流程取决于你是从Git仓库拉取(pull)代码还是向git仓库推送(push)代码。如果你是从Git仓库拉取(pull)代码,GitLab Rails应用会全权负责处理用户鉴权和执行Git命令的工作;如果你是向Git仓库推送(push)代码,GitLab Rails应用既不会进行用户鉴权也不会执行Git命令,它会把以下工作交由GitLab Shell进行处理:

调用GitLab Rails API
检查权限执行pre-receive钩子(在GitLab企业版中叫做Git钩子)
执行你请求的动作
处理GitLab的post-receive动作
处理自定义的post-receive动作

5、GitLab Workhorse

GitLab Workhorse是一个敏捷的反向代理。它会处理一些大的HTTP请求,比如文件上传、文件下载、Git push/pull和Git包下载。其它请求会反向代理到GitLab Rails应用,即反向代理给后端的unicorn。

二、Gitlab 的安装

1、安装和配置必要的依赖关系

sudo yum install -y curl policycoreutils-python openssh-server openssh-clients
sudo systemctl enable sshd
sudo systemctl start sshd

sudo firewall-cmd --permanent --add-service=http
sudo systemctl reload firewalld
sudo yum install postfix
sudo systemctl enable postfix
sudo systemctl start postfix

2、添加 Gitlab 仓库

新建/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

再执行

sudo yum makecache
sudo yum install gitlab-ce

版本管理 GitLab 的安装及管理 (CentOS 7)GitLab

3、配置external_url

版本管理 GitLab 的安装及管理 (CentOS 7)GitLab
版本管理 GitLab 的安装及管理 (CentOS 7)GitLab
编辑/etc/gitlab/gitlab.rb,设置external_url

vim /etc/gitlab/gitlab.rb

默认:
版本管理 GitLab 的安装及管理 (CentOS 7)GitLab
修改后:
版本管理 GitLab 的安装及管理 (CentOS 7)GitLab

4、启动gitlab

sudo gitlab-ctl reconfigure

5、浏览器访问192.168.45.146

版本管理 GitLab 的安装及管理 (CentOS 7)GitLab
重新设置密码:
确认密码:
账号(默认)root
密码:
版本管理 GitLab 的安装及管理 (CentOS 7)GitLab

gitlab访问错误Whoops, GitLab is taking too much time to respond

问题定位8080端口被占用:
解决方案01:
将占用的8080端口的进程杀死,重新启动gitlab
解决方案02:

external_url 'http://192.168.45.146

修改为没有使用的端口即可:

external_url 'http://192.168.45.146:8899'

将下面这3行打开注释
默认注释:

unicorn['port'] = 8088
postgresql['shared_buffers'] = "256MB"
postgresql['max_connections'] = 200

重新启动gitlab,即可

GitLab常用命令

# 启动GitLab
[[email protected]]# gitlab-ctl reconfigure
[[email protected]]# gitlab-ctl restart

sudo gitlab-ctl start    # 启动所有 gitlab 组件;
sudo gitlab-ctl stop        # 停止所有 gitlab 组件;
sudo gitlab-ctl restart        # 重启所有 gitlab 组件;
sudo gitlab-ctl status        # 查看服务状态;
sudo gitlab-ctl reconfigure        # 启动服务;
sudo vim /etc/gitlab/gitlab.rb        # 修改默认的配置文件;
gitlab-rake gitlab:check SANITIZE=true --trace    # 检查gitlab;
sudo gitlab-ctl tail        # 查看日志;

启动GitLab

[[email protected]]# gitlab-ctl reconfigure
[[email protected]]# gitlab-ctl restart
gitlab-ctl tail # 查看日志;

异常参考链接:
https://www.liangzl.com/get-article-detail-27713.html
https://blog.csdn.net/weixin_40816738/article/details/90442550


https://blog.csdn.net/vtopqx/article/details/80883127

  1. List item
  2. d
  3. d

同步时间:
ntpdate timel.aliyun.com

查看端口
netstat -tlnp

在线查看清华仓库中的gitlab镜像的版本信息:
yum list gitlab-ce

192.168.45.146

相关文章:

  • 2022-12-23
  • 2021-11-24
  • 2022-12-23
  • 2021-11-30
  • 2021-05-11
  • 2021-06-09
  • 2021-06-20
  • 2021-04-28
猜你喜欢
  • 2021-07-11
  • 2021-07-07
  • 2022-12-23
相关资源
相似解决方案