GitLab:如何搭建自己的代码托管服务器

1. 简介

在这里插入图片描述

官网地址:https://about.gitlab.com/

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

Gitlab和GitHub一样属于第三方基于Git开发的作品,免费且开源。与GitHub类似,可以注册用户,任意提交你的代码,添加SSHKey等等。不同的是,Gitlab可以部署到自己的服务器上,数据库等一切数据信息都掌握在自己手上,适合团队内部协作开发。简单来说可以把Gitlab看做是个人版的GitHub。

2. 安装

(1)安装相关依赖

yum -y install policycoreutils policycoreutils-python openssh-server openssh-clients postfix

(2)启动ssh服务&设置为开机启动

systemctl enable sshd && sudo systemctl start sshd

(3)设置postfix开机自启,并启动,postfix支持gitlab发信功能

systemctl enable postfix && systemctl start postfix

(4)开放ssh以及http服务,然后重新加载防火墙列表

firewall-cmd --add-service=ssh --permanent
firewall-cmd --add-service=http --permanent
firewall-cmd --reload

如果关闭防火墙就不需要做以上配置

(5)下载gitlab包,并且安装

# 在线下载安装包
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/gitlab-ce-12.9.4-ce.0.el6.x86_64.rpm
# 安装
rpm -i gitlab-ce-12.9.4-ce.0.el6.x86_64.rpm

(6)修改gitlab配置

vim /etc/gitlab/gitlab.rb

# 修改gitlab访问地址和端口,默认为80,我们改为82
external_url 'http://192.168.1.19:82'
nginx['listen_port'] = 82

(7)重载配置及启动gitlab

gitlab-ctl reconfigure
gitlab-ctl restart

(8)把端口添加到防火墙(如果关闭防火墙则不需要)

firewall-cmd --zone=public --add-port=82/tcp --permanent
firewall-cmd --reload

启动成功后,看到以下修改管理员root密码的页面,修改密码后,然后登录即可。

在这里插入图片描述

3. 使用

3.1 添加组

使用管理员 root 创建组,一个组里面可以有多个项目分支,可以将开发添加到组里面进行设置权限,不同的组就是公司不同的开发项目或者服务模块,不同的组添加不同的开发即可实现对开发设置权限的管理。

在这里插入图片描述

3.2 创建用户

创建用户的时候,可以选择Regular或Admin类型。其中:

  • Regular:普通用户,只能访问属于他的组和项目。
  • Admin:管理员,可以访问所有组和项目。

在这里插入图片描述

创建完用户后,立即修改密码。

在这里插入图片描述

3.3 添加用户到组中

选择mini-mall-group组,进行Members管理组的成员。

在这里插入图片描述

在这里插入图片描述

Gitlab 用户在组里面有5种不同权限:

  • Guest:可以创建issue、发表评论,不能读写版本库;
  • Reporter:可以克隆代码,不能提交。QA、PM可以赋予这个权限;
  • Developer:可以克隆代码、开发、提交、push,普通开发可以赋予这个权限;
  • Maintainer:可以创建项目、添加tag、保护分支、添加项目成员、编辑项目,核心开发可以赋予这个权限;
  • Owner:可以设置项目访问权限 - Visibility Level、删除项目、迁移项目、管理组成员,开发组组长可以赋予这个权限。

3.4 在用户组中创建项目

在这里插入图片描述

至此,Gitlab的安装以及简单使用已经完成,接下来我们就可以往mini-mall工程提交代码了。

——End——
更多精彩分享,可扫码关注微信公众号哦。

在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章