首页 > 其他分享 >Gitlab以及分支管理

Gitlab以及分支管理

时间:2024-07-26 15:54:40浏览次数:10  
标签:Git 管理 仓库 代码 Gitlab git 开发者 节点 分支

一、概述

Git 是一个分布式版本控制系统,用于跟踪文件的变化,尤其是源代码的变化。它由 Linus Torvalds 于 2005 年开发,旨在帮助管理大型软件项目的开发过程。

二、Git 的功能特性
Git 是关注于文件数据整体的变化,直接会将文件提交时的数据保存成快照,而非仅记录差异内容,并且使用SHA-1加密算法保证数据的完整性。主要功能如下:
1.克隆数据库版本:从服务器上克隆版作数据库(包括代码和版本信息)到本机上;
2.提交代码:在本机上自己创建的分支智是交代码;
合并分支:在本机上合并分支;3.
拉取合并分支:新建一个分支,把服务器上最新版的代码 Fetch 下来,然后跟自己的主分支合并;
代码冲突解决:一般开发者之间解决冲突的方法,开发者之间可以使用 pu 命令解决冲突,解决完冲突之后再向主开发者提交补丁。

三、Github社区
GitHub 是一个面向开源及私有软件项目的托管平台,因为只支持 Git 作为唯一的版本库格式进行托管,故名 GitHub。GitHub 可以提供给用户空间创建 Git 仓储,保存用户的一些数据文档或者代码等
GitHub 作为开源代码库以及版本控制系统,目前拥有 140 多万开发者用户,随着越多的应用程序转移到了云上,GitHub 已经成为了管理软件开发以及发现已有代码的首选方法。
GitHub 可以托管各种 Git 月,幷提供一个 Web 界面,但与其它像 SourceForge 或 Google Code这样的服务不同,GitHub的独特卖点在于从另外一个项目进行分支的简易性。为一个项目贡献代码非常简单:首先,点击项目站点的“fork"的按钮,然后将代码检出并将修改加入到刚才分出的代码库中,最后通过内建的"pull request”机制向项目负责人申请代码合并。

四、Gitlab
GitLab 是一个基于 Git 的项目管理软件用于仓库管理系统的开源项目。使用 Git 作为代码管理工具,并在此基础上搭建起来 Web 服务。
GitLab 主要针对软件开发过程中产生的代码和文档进行管理,支持 group 和 project 两个维度进行代码和文档的管理。其中,group 是群组,可以有多个roject;project是工程项目,一个project 中可能包含多个 branch,意为每个项目中有多个分支,分支间相互独立,不同分支可以进行归并。Gitlab 一站式 DevOps 平台,加速和优化软件开发全生命周期。

五、集中式与分布式的区别
1、集中式概述

集中式版本控制系统(例如SVN)将代码库存储在一台中央服务器上,团队成员通过客户端从中央服务器获取代码并将更改提交到服务器。这意味着代码库是集中的,所有开发者都在同一个代码库上工作,并且必须与服务器进行通信才能查看历史记录和获取代码。因此,如果服务器发生故障或网络中断,会导致数据丢失,并且开发者将无法使用代码库。

2、分布式概述
分布式版本控制系统(例如Git)则将完整的代码库复制到每个开发者的本地计算机上,每个开发者都有自己的完整副本,可以在没有网络连接的情况下继续工作。开发者可以在本地进行代码的修改和提交,然后将更改推送到其他开发者的本地副本中。因此,代码库是分散的,每个开发者都有自己的代码库和历史记录,可以独立工作并在不同的分支上开发代码。

像集中式都有一个主版本号,所有的版本迭代都以这个版本号为主,而分布式因为每个客户端都是服务器,git 没有固定的版本号,但是有一个由哈希算法算出的id,用来回滚用的,同时也有一个 master 仓库,这个仓库是一切分支仓库的主仓库,我们可以推送提交到 master 并合并到主仓库上,主仓库的版本号会迭代一次,我们客户端上的 git 版本号无论迭代多少次,都跟 master 无关,只有合并时 master 才会迭代一次。

六、集中式和分布式的优缺点
1、分布式
(1)优点
1.灵活性:由于每个节点都有完整的代码库,因此可以更轻松地进行并行工作,不同的开发人员可以在不同的分支上独立工作,提高工作效率。
2.可扩展性:由于每个节点都有完整的代码库,因此可以更容易地扩展系统以适应更大的开发团队或项已害求。
3.独立性:包公节点都可以独立工作,不需要依赖于中央服务器或其他节点,提高了系统的可用性和稳定性。

(2)缺点
1.安全性:由于每个节点都有完整的代码库,如果某个节点被攻击或出现故障,可能会造成源代码泄露,影响到整个系统的安全性。
2.数据一致性:由于每个节点都有自己的代码库和历史记录,因此在合并不同节点的更改时可能会出现数据一致性问题。

2.集中式

1.简单易用:集中式版本控制系统通常具有简单明了的设计,易于理解和实施。由于所有的决策和处理都由中心节点完成,客户端设备只需执行简单的操作即可得到所需的服务。2.数据安全性:由于所有数据都存储在中央服务器上,因此可《更更好地保护数据的完整性和安全性。
3.管理方便:集中式版本控制系统通常具有集中的管理和控制能力,可以更/容易地进行系统维护和管理。
(2)缺点
1.单点故障:由于整个系统依赖于中心节点,一旦中心节点出现故障或不可用,整个系统将无法正常运行。这导致系统的可靠性受到了限制,并增加了系统的风险,
2.性能瓶颈:在集中式版本控制系统中,所有的数据处理和决策都需要通过中心节点进行。当系统负载增大时,中心节点可能成为性能瓶颈,限制了整个系统的处理能力。
3.可扩展性有限:由于所有的处理都由中心节点完成,集中式版本控制系统的可扩展性受到限制。当系统需要扩展以满足更大规模的需求时,需要升级和改变中心节点,导致系统的扩展性有限。

七、Git 的安装及配置

1、Git 安装

2、配置 git 环境 参数:

config:配置 git 环境

--global:长命令表示配置整个 git 环境

八、Git 的基本流程

1. 在工作目录 (工作区) 中修改某些文件

2. 对已修改文件作快照,并保存到暂存区域 git add .

3. 将保存在暂存区的文件快照提交到版本库 git commit -m ""

4. 查看提交历史 git log 1、创建本地空仓库 init:初始化当前目录为仓库,初始化后会自动将当前仓库设置为 master 创建本地仓库的条件是需要一个空目录,然后在空目录中初始化你的项目 (1)创建一个名为 test 的空项目

2、新建文件添加到本地仓库 add:将文件添加到缓存区 commit:提交到本地仓库 (1)新建文件并添加到缓存 (2)提交文件到仓库 使用-m命令来简写描述我们的信息,如果不使用-m,会调用终端的注释编 辑器来输入描述信息,而不建议使用注释编辑器,因为注释编辑器比较难 用,不舒服。 

git commit 会为我们生成40位的哈希值,用于作为 id,并把刚刚用 git add 添加到提交缓存区里的文件提交到本地仓库中,便于我们回滚,至此,这个 文件就已经添加到本地仓库中了,同时本地仓库也迭代了一个版本。

3、查看历史提交信息

标签:Git,管理,仓库,代码,Gitlab,git,开发者,节点,分支
From: https://blog.csdn.net/m0_72009757/article/details/140693901

相关文章

  • 高效项目管理的秘诀:顶级多项目软件推荐
    国内外主流的10款多项目进度软件对比:PingCode、Worktile、Teambition、烽火台、明道云、TAPD、Monday.com、Asana、Jira、Basecamp。在管理多个项目的复杂过程中,选择合适的进度管理软件通常是项目成功的关键。许多项目经理面临的一个主要挑战是如何有效地同步多个项目的进度,确......
  • 基于SpringBoot大学菜鸟驿站管理系统设计和实现(源码+LW+调试文档)
    完整视频演示:请联系我获取更详细的演示视频功能截图:核心代码参考:  /***登录相关*/@RequestMapping("users")@RestControllerpublicclassUserController{@AutowiredprivateUserServiceuserService;@AutowiredprivateTo......
  • 基于SpringBoot天气预报管理系统设计和实现(源码+LW+调试文档)
    完整视频演示: 请联系我获取更详细的演示视频功能截图:核心代码参考:  /***登录相关*/@RequestMapping("users")@RestControllerpublicclassUserController{@AutowiredprivateUserServiceuserService;@Autowire......
  • 软考-软件设计师(2)-操作系统概述:多级索引、PV操作、段页式存储、磁盘管理、进程管理
    场景软考-软件设计师-操作系统概述模块高频考点整理。以下为高频考点、知识点汇总,不代表该模块所有知识点覆盖,请以官方教程提纲为准。注:博客:霸道流氓气质-CSDN博客实现知识点文件系统多级索引求文件系统多级索引的最大长度二级索引=一级索引*一级索引*大小某文件系统......
  • forms.ModelMultipleChoiceField 与 widget=FilteredSelectMultiple 不适用于自定义新
    我试图在自定义的新管理表单页面上显示forms.ModelMultipleChoiceField但它似乎没有像在已经制作的Django页面上显示的方式显示,例如模型产品Django管理页面。我的forms.ModelMultipleChoiceField看起来像这样:显示我的forms.ModelMultipleChoiceField是什么样子......
  • 在KubeSphere 容器中快速部署使用 GitLab 并构建 DevOps 项目
    前提条件安装KubeSphere,认真阅读全文可免费领取PetaExpress云服务器一台。在KubeSphere中启用DevOps套件**参考:启用DevOps**https://kubesphere.io/zh/docs/v3.4/pluggable-components/devops/安装GitLabCE我们先这次的演练创建一个名为devops的企业空间,同时创建一个名为gi......
  • 新品上市—EtherCAT分支器
    EteherCAT分支器一共4个EtherCAT网口,一进三出,数据帧处理顺序IN→0UT4→0UT2→0UT3。EteherCAT分支器,将简单的线性拓扑改造为多级星型拓扑,达到一入多出的效果,适用于工艺复杂的应用现场。拓扑图如下(级联的个数仅与主站所支持最大节点数有关。每个分支器占用1个EtherCAT从站站号......
  • 教育行业的知识管理怎么用?五步让你提升70%工作效率
    与大学和其他学习机构相关的资源是什么?是知识。这些学术机构是知识、见解和智慧的宝库,这些知识被传授给各个年龄段的学生。但是,除了学术领域之外,大学还可以被其他类型的知识所淹没,这些知识可以被更有效地用于学习和成长。例如,在大学中,行政部门认识到需要改进新教师入职流程......
  • PMP-管理要素、组织结构类型、组织治理框架
    组织治理框架组织治理governance(注重过程)指组织各个层面的有组织的或有结构的安排、旨在确定和影响组织成员的行为。治理是在组织内行使职权的框架。治理框架会影响组织目标的设定和实现方式;风险监控和评估方式;绩效优化方式。审计就是治理工具,比如财务审计......
  • IT实战课堂计算机毕业设计精品基于java的旅游景点管理网站SSM
    项目功能简介:《基于java的旅游网站ssm》该项目含有源码、文档等资料、配套开发软件、软件安装教程、项目发布教程等使用技术:开发语言:Java框架:ssm技术:JSPJDK版本:JDK1.8服务器:tomcat7数据库:mysql5.7数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:Mav......