GitLab企业级代码管理仓库

原文:https://www.cnblogs.com/wsnbba/p/10171052.html

 

 
  • 使用GitHub或者码云等公共代码仓库
  • 使用GitLab私有仓库

 GitLab是什么?

是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务。基础功能免费,高级功能收费。

为什么要使用GitLab?

基础功能开源,可自行搭建 
可以进行权限控制,使得代码对部分人可见 
gitlab使用方便

官方安装文档:https://about.gitlab.com/installation/#centos-7

GitLab国内源下载地址:https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/

在Git02上装GitLab

初始环境

主机名

IP

备注

Git01

10.1.1.128

Git客户端

Git02

10.1.1.129

GitLab服务器

安装GitLab

利用yum安装本地指定的rpm包,好处是自动解决依赖问题

初始化GitLab,只需要执行一次

查看GitLab启动状态

查看GitLab版本号

在宿主机输入http:/IP就可以访问了,并给管理员用户设定密码

最少8位

登录管理员账号:root       密码:66666666

登陆后,就可以选择如下功能使用了

GitLab中文社区版补丁包安装

备份英文版GitLab

将中文补丁包的内容覆盖英文版

重新配置GitLab

重新启动GitLab

重新刷新浏览器访问GitLab

使用GitLab

创建一个新项目

修改GitLab配置文件/etc/gitlab/gitlab.rb

我们需要修改GitLab的默认访问域名(因为我们是在内网搭建的GitLab),GitLab的默认监听端口是80,但是在企业中这个端口经常被别的服务占用,所以还需要更换端口号

修改后的两行内容

重新配置GitLab

重新启动GitLab

重新访问浏览器http://10.1.1.129:8888

 

 

尝试将本地仓库代码推送到私有GitLab

在Git01客户端上做

 

刷新浏览器

推送本地仓库标签v1.0到远程仓库GitLab上

尝试在本地仓库克隆GitLab的项目v1.0标签到本地仓库

推送本地仓库linux分支到远程仓库GitLab上

 

克隆远程仓库GitLab的linux分支

克隆的时候加参数-b指定你要克隆的分支  不指定默认克隆的是master分支

配置GitLab的ssh秘钥连接方式

在Git01上生成秘钥对

将公钥的内容复制到GitLab上

在浏览器端打开GitLab

添加成功

利用ssh方式克隆GitLab上的一个项目

 

配置GitLab邮件服务

配置邮箱服务的用途:1,有合并请求时,邮件通知  2,账户注册时,邮件验证   3,修改密码时,通过邮件修改

配置步骤:开启qq邮箱的smtp服务,修改gitlab配置,测试邮件服务是否正常

开启GitLab服务的postfix服务并开启qq邮箱的smtp服务

修改GitLab配置文件/etc/gitlab/gitlab.rb

修改成如下

重新加载GitLab配置文件

重新启动GitLab

进入GitLab控制台进行邮件发送测试

开启GitLab控制台

GitLab的账号注册及分组

账号注册测试

 

我们在注册的时候,邮箱乱写能注册并登陆,显然在企业是绝对不允许的

开启GitLab邮箱验证功能

重新登陆管理员用户root,密码66666666,进行如下操作

退出时别忘了保存修改的设置如下图

然后退出管理员的登录,进行重新注册

 

由上图发现,此时注册用户,已经进不去GitLab了,这是因为GitLab已经自动发了一封邮件给注册用户的邮箱,需要用户进行邮件确认后,方可登录。

 创建一个项目组

给组添加成员并授权

 

  • Guest访客: 
    • 只能发表评论,不能读写项目库
  • Reporter报告者: 
    • 只能克隆代码(读),不能提交代码(修改)(产品测试)
  • Developer开发人员: 
    • 可以进行代码的读写(普通程序员)
  • Master主程序员: 
    • 可以添加项目成员,添加标签,创建和保护分支(产品经理)
  • Owner所有者: 
    • 拥有所有权限(一般不用此权限)

 

添加权限成功后,GitLab会自动邮件通知这个用户

 给项目组创建一个新项目

 

进行组成员的项目提交和克隆测试

再创建一个普通程序员(开发人员)的账号

 测试克隆GitLab到本地仓库

测试将本地仓库master分支的改变推到GitLab上

测试结果推送失败,因为开发人员没有这个权限,开发人员没有权限修改GitLab上master分支

测试提交除master的分支到GitLab

说明:普通的开发人员没有权限修改master分支的代码,但是他可以任意创建自己的分支,不能提交到GitLab更不能合并了,在本地仓库可以合并,但是本地仓库合并完了并不能修改master,没有作用,真正的仓库合并,是要在web界面合并的,也就是说在GitLab上的版本合并才是真正的合并,本地合并只是本地的,本地合并完了是推不到master的,推不到就没用。只有主程序员才可以本地合并推到GitLab进行版本合并。

 
 
 
原文地址:https://www.cnblogs.com/shihaiming/p/11600771.html