GitLab简介 GitLab 是一个用于仓库管理系统的开源项目。使用Git作为代码管理工具,并在此基础上搭建起来的web服务。可 通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可 以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊 天程序(Wall)进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用。 常用的网站:
官网:https://about.gitlab.com/
国内镜像:https://mirrors.tuna.tsinghua.edu.cn/gitlab‐ce/yum/
git官网https://about.gitlab.com/installation/#centos‐7
下载方式可通过 国内清华源gitlab‐ce社区版本下载
安装环境:
1、 CentOS 6或者7
2、 2G内存(实验)生产(至少4G)
3、 安装包:gitlab‐ce‐10.2.2‐ce
4、 禁用防火墙,关闭selinux
1.安装部署
官方下载安装包或上传本地安装包
#安装必须要的依赖
yum install -y curl policycoreutils-python openssh-server
#安装上传的包
[root@sweb01 /test]# rpm -ivh gitlab-ce-10.2.2-ce.0.el7.x86_64.rpm
#修改配置文件
[root@sweb01 ~]# vim /etc/gitlab/gitlab.rb file
external_url 'http://10.0.0.51'
#重新配置
[root@sweb01 ~]# gitlab-ctl reconfigure
#检查启动状态
[root@sweb01 /test]# gitlab-ctl status
gitlab‐ctl reconfigure # 更改配置文件后需重新配置
/opt/gitlab/ # gitlab的程序安装目录
/var/opt/gitlab # gitlab目录数据目录
/var/opt/gitlab/git‐dfata # 存放仓库数据
gitlab‐ctl status # 查看目前gitlab所有服务运维状态
gitlab‐ctl stop # 停止gitlab服务
gitlab‐ctl stop nginx # 单独停止某个服务
gitlab‐ctl tail # 查看所有服务的日志
通过浏览器输入IP地址进行访问gitlab 10.0.0.203
- Gitlab的服务构成
nginx: 静态web服务器
gitlab‐workhorse: 轻量级的反向代理服务器
logrotate:日志文件管理工具
postgresql:数据库
redis:缓存数据库
sidekiq:用于在后台执行队列任务(异步执行)。(Ruby)
unicorn:An HTTP server for Rack applications,GitLab Rails应用是托管在这个服务器上面的。(Ruby Web Server,主要使用Ruby编写)
gitlab汉化:
1、下载汉化补丁 git clone https://gitlab.com/xhang/gitlab.git
2、查看全部分支版本 git branch ‐a
3、对比版本、生成补丁包 git diff remotes/origin/10‐2‐stable remotes/origin/10‐2‐stable‐zh > ../10.2.2‐zh.diff
4、停止服务器 gitlab‐ctl stop
5、打补丁 patch ‐d /opt/gitlab/embedded/service/gitlab‐rails ‐p1 < /tmp/10.2.2‐zh.diff
6、启动和重新配置
gitlab‐ctl start
gitlab‐ctl reconfigure
2.web页面配置
-
修改log
3.Gitlab项目部署
项目创建规则
1、创建项目组
2、创建项目
3、创建成员或添加
-
创建组
-
创建项目
-
创建秘钥连接
[root@sweb01 /test]# ssh-keygen -t rsa
[root@sweb01 /test]# cat /root/.ssh/id_rsa.pub
-
返回项目组,开始创建项目
-
本地仓库代码推送完成刷新当前页面
3.创建新的代码测试推送
[root@sweb01 ~/data]# touch test.txt
[root@sweb01 ~/data]# git add .
[root@sweb01 ~/data]# git commit -m "newfile test.txt"
[root@sweb01 ~/data]# git push -u origin master
流程总结:
1、在本地仓库创建或修改代码
2、将修改完成后的代码推送到暂存区
3、将暂存区的代码推送到本地仓库
4、将本地仓库的代码推送到gitlab远程仓库中
4.访问权限管理
-
关闭注册功能
-
给开发开通用户
-
设置用户密码
-
将新用户添加到项目组
-
分支保护(不允许直接合并master)
-
测试登录dev用户(同电脑采用第二款浏览器)
-
开发用户需配置SSH
[root@db02 ~]# git clone git@10.0.0.51:test/git_data.git
[root@db02 ~]# cd git_data/
[root@db02 ~/git_data]# git config --global user.email "dev@example.com"
[root@db02 ~/git_data]# git config --global user.name "dev"
[root@db02 ~/git_data]# touch newfile.txt
[root@db02 ~/git_data]# git commit -m "newfile.txt"
[root@db02 ~/git_data]# git push -u origin dev
-
发生请求合并
-
管理员用户评判分支合并消息
dev分支点合并后作废,需删除旧分支点。如后期更改需要重新创建dev分支点。
每个节点在工作开始前,一定要和远程仓库保持一致性
5.流程总结
项目的创建:
1、创建组
2、创建项目
3、创建成员并添加密码
4、将成员加入到项目组
5、创建master主节点分支保护
开发上传代码流程:
1、登录账户,并查看项目
2、将本地ssh免秘钥发送上远程仓库,拉取远程仓库master节点上的数据
3、创建新的远程分支点
4、写完将代码推送至远程仓库分支点,并发送合并主master节点请求
管理者:
1、查看接收的合并请求,认真确认内容不误后,开启合并。同时删除旧分支点。
开发二次修改流程:
1、删除旧分支点。
2、重新拉取远程仓库master节点代码
3、创建新的分支点工作