GitLab代码托管服务器安装

2022/5/19 other

# GitLab简介

img

官网:https://about.gitlab.com/ (opens new window)

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

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

# Gitlab安装

1.安装相关依赖

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

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

systemctl enable sshd && sudo systemctl start sshd
1

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

systemctl enable postfix && systemctl start postfix
1

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

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

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

5.下载gitlab包,并且安装 在线下载安装包: wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/gitlab-ce-12.4.2-ce.0.el6.x86_64.rpm

​ 如果出现报错:

ERROR: cannot verify mirrors.tuna.tsinghua.edu.cn‘s certificate, issued by ‘/C=US/O=Let‘s Encrypt/CN
1

wget 后加入no-check-certificate即可解决

​ 安装:

rpm -i gitlab-ce-12.4.2-ce.0.el6.x86_64.rpm
1

6.修改gitlab配置

vi /etc/gitlab/gitlab.rb
1

修改gitlab访问地址和端口,默认为80,我们改为82

# 外部访问地址
external_url 'http://192.168.3.25:82'
# 访问端口,默认80
nginx['listen_port']=82
1
2
3
4

7.重载配置及启动gitlab

gitlab-ctl reconfigure
1
gitlab-ctl restart
1

8.把端口添加到防火墙

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

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

GitLab2

# gitlab 常用命令

启动所有 gitlab 组件

gitlab-ctl start
1

停止所有 gitlab 组件

gitlab-ctl stop
1

重启所有 gitlab 组件

gitlab-ctl restart
1

查看服务状态

gitlab-ctl status
1

启动服务

gitlab-ctl reconfigure
1

修改默认的配置文件

vim /etc/gitlab/gitlab.rb
1

检查gitlab

gitlab-rake gitlab:check SANITIZE=true --trace
1

查看日志

gitlab-ctl tail
1

# Gitlab添加组、创建用户、创建项目

# 创建组

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

create_group

create_group2

# 创建用户

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

Regular: 普通用户,只能访问属于他的组合项目

Admin:管理员,可以访问所有组合项目

create_user

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

pass

# 将用户添加到组中

选择某个用户组,进行Members管理组的成

add_group

img232

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

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

# 在用户组中创建项目

以刚才创建的新用户身份登录到Gitlab,然后在用户组中创建新的项目

c_project

c_project2

创建完后,我们就可以试试clone了

clone

clone2

随便新建几个文件,测试push

push

到此,我们的个人GitLab代码托管的服务器就部署成功了