版本控制gitlab

版本控制gitlab

一 版本控制介绍

版本控制是指对软件开发过程中各种程序代码、配置文件及说明文档等文件变更的管理,是软件配置管理的核心思想之一。
版本控制最主要的功能就是追踪文件的变更。它将什么时候、什么人更改了文件的什么内容等信息忠实地了记录下来。每一次文件的改变,文件的版本号都将增加。除了记录版本变更外,版本控制的另一个重要功能是并行开发。软件开发往往是多人协同作业,版本控制可以有效地解决版本的同步以及不同开发者之间的开发通信问题,提高协同开发的效率。并行开发中最常见的不同版本软件的错误(Bug)修正问题也可以通过版本控制中分支与合并的方法有效地解决。
具体来说,在每一项开发任务中,都需要首先设定开发基线,确定各个配置项的开发初始版本,在开发过程中,开发人员基于开发基线的版本,开发出所需的目标版本。当发生需求变更时,通过对变更的评估,确定变更的影响范围,对被影响的配置项的版本进行修改,根据变更的性质使配置项的版本树继续延伸或产生新的分支,形成新的目标版本,而对于不受变更影响的配置项则不应发产生变动。同时,应能够将变更所产生的对版本的影响进行记录和跟踪。必要时还可以回退到以前的版本。例如当开发需求或需求变更被取消时,就需要有能力将版本回退到开发基线版本。在曾经出现过的季度升级包拆包和重新组包的过程中,其实就是将部分配置项的版本回退到开发基线,将对应不同需求的不同分支重新组合归并,形成新的升级包版本。
版本控制是软件配置管理的核心功能。所有置于配置库中的元素都应自动予以版本的标识,并保证版本命名的唯一性。版本在生成过程中,自动依照设定的使用模型自动分支、演进。除了系统自动记录的版本信息以外,为了配合软件开发流程的各个阶段。还需要定义、收集一些元数据来记录版本的辅助信息和规范开发流程,并为今后对软件过程的度量做好准备。当然如果选用的工具支持,这些辅助数据将能直接统计出过程数据,从而方便软件过程改进活动的进行。对于配置库中的各个基线控制项,应该根据其基线的位置和状态来设置相应的访问权限。一般来说,对于基线版本之前的各个版本都应处于被锁定的状态,如需要对它们进行变更,则应按照变更控制的流程来进行操作。

二 gitlab部署

安装前期准备

gitlab 需要安装在一台独立的服务器上
演示环境
Centos8
配置yum源
#配置yum源 
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo
配置epel源
#配置epel源 
yum install -y https://mirrors.aliyun.com/epel/epel-release-latest-8.noarch.rpm 
yum clean all   
关闭防火墙和SElinux
systemctl stop firewalld.service 
systemctl disable firewalld.service
setenforce 0

安装部署gitlab

配置GitLab 软件源镜像。

curl -fsSL https://packages.gitlab.cn/repository/raw/scripts/setup.sh | /bin/bash
安装GitLab。确保已正确设置 DNS,并更改 https://gitlab.example.com 为您要访问GitLab 实例的 URL。安装包将在该 URL 上自动配置和启动

GitLab。

对于 https 站点,GitLab 将使用 Let’s Encrypt 自动请求 SSL 证书,这需要有效的主机名和入站 HTTP 访问。您也可以使用自己的证书或仅使用 http://(不带s)。
如果您想为初始管理员用户(root)指定自定义密码,请查看文档。如果未指定密码,将自动生成随机密码。
vim /etc/gitlab/gitlab.rb
external_url "https://192.168.1.81"         # Must use https protocol
开始安装:
sudo EXTERNAL_URL="https://gitlab.example.com" yum install -y gitlab-jh
gitlab-ctl reconfigure
登录
在安装过程中指定了自定义密码,否则将随机生成一个密码并存储在 /etc/gitlab/initial_root_password 文件中(出于安全原因,24 小时后,此文件会被第一次 gitlab-ctl reconfigure 自动删除,因此若使用随机密码登录,建议安装成功初始登录成功之后,立即修改初始密码)。使用此密码和用户名 root 登录。
vim /etc/gitlab/initial_root_password 
Password: 921wFEpflRw81mntFgT0qEgMJfJaFgFhc0R3IeI4cEI=

在这里插入图片描述

三、使用手册

Gitlab中主要围绕项目,用户,团队三个概念进行操作。

1.个人使用

如果是作为个人使用,那么登录创建project就可以实现上传下载代码以及文档撰写了。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

[root@centos81 ~]# git config --global user.email  "root@whd.com"
遇到错误
[root@centos81 ~]# git clone https://192.168.1.81/root/whd.git
正克隆到 'whd'...
致命错误:无法访问 'https://192.168.1.81/root/whd.git/':SSL certificate problem: self signed certificate
解决办法
[root@centos81 ~]# export GIT_SSL_NO_VERIFY=true
[root@centos81 ~]# git config --global http.sslVerify "false"
再次执行
root@centos81 ~]# git clone https://192.168.1.81/root/whd.git
正克隆到 'whd'...

(gnome-ssh-askpass:56674): Gtk-WARNING **: 03:17:51.554: cannot open display: localhost:11.0
错误:unable to read askpass response from '/usr/libexec/openssh/gnome-ssh-askpass'
解决办法
[root@centos81 ~]# unset SSH_ASKPASS
[root@centos81 ~]# git clone https://192.168.1.81/root/whd.git
正克隆到 'whd'...
Username for 'https://192.168.1.81': root
Password for 'https://root@192.168.1.81': 
remote: Enumerating objects: 3, done.
remote: Counting objects: 100% (3/3), done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
接收对象中: 100% (3/3), 完成.

创建一个内容并上传
[root@centos81 ~]# cd whd/
[root@centos81 whd]# git switch --create whd
切换到一个新分支 'whd'
[root@centos81 whd]# echo "6666666666666" > test                  #新建一个文件并传入内容 
[root@centos81 whd]# ls
README.md  test
[root@centos81 whd]# git add test 
[root@centos81 whd]# git commit -m "first commit"
[whd 525173f] first commit
 1 file changed, 1 insertion(+)
 create mode 100644 test
[root@centos81 whd]# git push --set-upstream origin whd
Username for 'https://192.168.1.81': root
Password for 'https://root@192.168.1.81': 
枚举对象中: 4, 完成.
对象计数中: 100% (4/4), 完成.
使用 4 个线程进行压缩
压缩对象中: 100% (2/2), 完成.
写入对象中: 100% (3/3), 264 字节 | 264.00 KiB/s, 完成.
总共 3(差异 0),复用 0(差异 0),包复用 0
remote: 
remote: To create a merge request for whd, visit:
remote:   https://192.168.1.81/root/whd/-/merge_requests/new?merge_request%5Bsource_branch%5D=whd
remote: 
To https://192.168.1.81/root/whd.git
 * [new branch]      whd -> whd
分支 'whd' 设置为跟踪 'origin/whd'。
验证

在这里插入图片描述
在这里插入图片描述

修改账号密码

在这里插入图片描述
在这里插入图片描述

gitlab常用管理操作

项目管理(通常只是创建新项目)
创建成员组(针对某个项目创建一个成员组)
用户管理(此用户乃gitlab用户而非系统用户)
来了新员工,为其添加gitlab用户
员工离职,将其gitlab用户禁用或删除
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值