GitLab基本介绍
GitLab是利用Ruby on Rails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。
与Github类似,GitLab能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊天程序(Wall)进行交流。
它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。
Git的家族成员
Git:是一种版本控制系统,是一个命令,是一种工具。
Gitlib:是用于实现Git功能的开发库。
Github:是一个基于Git实现的在线代码托管仓库,包含一个网站界面,向互联网开放。
GitLab:是一个基于Git实现的在线代码仓库托管软件,你可以用gitlab自己搭建一个类似于Github一样的系统,一般用于在企业、学校等内部网络搭建git私服。
Gitlab的服务构成
Nginx:静态web服务器。
gitlab-shell:用于处理Git命令和修改authorized keys列表。
gitlab-workhorse: 轻量级的反向代理服务器。
logrotate:日志文件管理工具。
postgresql:数据库。
redis:缓存数据库。
sidekiq:用于在后台执行队列任务(异步执行)。
unicorn:An HTTP server for Rack applications,GitLab Rails应用是托管在这个服务器上面的。
GitLab工作流程
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动作
GitLab Workhorse
GitLab Workhorse是一个敏捷的反向代理。它会处理一些大的HTTP请求,比如文件上传、文件下载、Git push/pull和Git包下载。其它请求会反向代理到GitLab Rails应用,即反向代理给后端的unicorn。
Gitlab环境部署
配置请参考:CentOS7下Gitlab安装
GitLab常用命令
# gitlab-ctl start # 启动所有 gitlab 组件;
# gitlab-ctl stop # 停止所有 gitlab 组件;
# gitlab-ctl restart # 重启所有 gitlab 组件;
# gitlab-ctl status # 查看服务状态;
# gitlab-ctl reconfigure # 启动服务;
# gitlab-rake gitlab:check SANITIZE=true --trace # 检查gitlab;
# gitlab-ctl tail # 查看日志;
GitLab使用
登录GitLab
新版本的gitlab登陆会要求修改root密码,而旧版本第一次登录使用的用户名和密码为 root 和 5iveL!fe。首次登录会强制用户修改密码。密码修改成功后,输入新密码进行登录。
创建开发组和用户
点击Admin Area点击New group创建新组;
创建名为proj1的项目组。
点击Admin Area点击New user创建名为dev1的普通用户,创建完成需要在Edit中添加默认密码,否则无法登陆gitlab;
创建Project
1、安装Git工具linux:安装Git,使用自带的源安装。
[root@localhost opt]# yum -y install git
2、生成密钥文件:使用ssh-keygen生成密钥文件.ssh/id_rsa.pub。
3.在GitLab的主页中新建一个Project
将dev1用户添加到项目成员中,权限等级为管理者;
4.登陆dev1的账号,添加ssh key导入步骤2中生成的密钥文件内容:
项目地址,该地址在进行clone操作时需要用到:
简单配置
1、配置使用Git仓库的人员姓名(dev1)
[root@localhost opt]# git config --global user.name "dev1"
2、配置使用Git仓库的人员email,填写自己的公司邮箱
[root@localhost opt]# git config --global user.email "dev1@test.com"
3、克隆项目,在本地生成同名目录,并且目录中会有所有的项目文件
[root@localhost opt]# git clone git@192.168.10.142:proj1/app.git
上传文件
1、进入到项目目录
[root@localhost opt]# cd app/
2、创建需要上传到GitLab中的目标文件
[root@localhost app]# echo “test” > test.sh
3、查看git状态
[root@localhost app]# git status
4、将test.sh文件加入到索引中
[root@localhost app]# git add test.sh
5、将test.sh提交到本地仓库
[root@localhost app]# git commit -m “test.sh”
6、将文件同步到GitLab服务器上
[root@localhost app]# git push -u origin master
7、上传成功后页面会显示文件内容