一、前言
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)
3、GitLab工作流程
版本管理 GitLab 的安装及管理 (CentOS 7)
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
3、配置external_url
编辑/etc/gitlab/gitlab.rb,设置external_url
vim /etc/gitlab/gitlab.rb
默认:
修改后:
4、启动gitlab
sudo gitlab-ctl reconfigure
5、浏览器访问192.168.45.146
重新设置密码:
确认密码:
账号(默认)root
密码:
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
- List item
- d
- d
同步时间:
ntpdate timel.aliyun.com
查看端口
netstat -tlnp
在线查看清华仓库中的gitlab镜像的版本信息:
yum list gitlab-ce
192.168.45.146