当前位置: 首页 > news >正文

Gitlab以及分支管理

一、概述

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、查看历史提交信息

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • ubuntu20.04 开源鸿蒙源码编译配置
  • 微软蓝屏事件:网络安全与系统稳定性的深刻反思
  • elementUI点击el-card选中边框变色
  • photoshop学习笔记——选区3
  • Github 2024-07-27开源项目日报 Top10
  • 4 款最佳 C# 无头浏览器
  • 基于SpringBoot+Vue的在线政务服务中心(带1w+文档)
  • 计算机体系结构:缓存一致性ESI
  • Java(十)——接口
  • 【中项】系统集成项目管理工程师-第8章 信息安全工程-8.2信息安全系统
  • 浏览器自动化测试工具selenium——爬虫操作记录
  • 每天一个数据分析题(四百五十八)- 根因分析
  • 基于SpringBoot+Vue的热门网游推荐网站(带1w+文档)
  • 使用requests库进行网络爬虫:入门指南
  • upload-labs靶场(1-19关)
  • [译]如何构建服务器端web组件,为何要构建?
  • 【技术性】Search知识
  • js
  • VirtualBox 安装过程中出现 Running VMs found 错误的解决过程
  • vuex 笔记整理
  • Windows Containers 大冒险: 容器网络
  • 理解 C# 泛型接口中的协变与逆变(抗变)
  • 微服务入门【系列视频课程】
  • Oracle Portal 11g Diagnostics using Remote Diagnostic Agent (RDA) [ID 1059805.
  • Semaphore
  • ​HTTP与HTTPS:网络通信的安全卫士
  • # Java NIO(一)FileChannel
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (附源码)计算机毕业设计SSM智能化管理的仓库管理
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (四)activit5.23.0修复跟踪高亮显示BUG
  • (转)http-server应用
  • (转)shell中括号的特殊用法 linux if多条件判断
  • ***php进行支付宝开发中return_url和notify_url的区别分析
  • ***原理与防范
  • .helper勒索病毒的最新威胁:如何恢复您的数据?
  • .htaccess 强制https 单独排除某个目录
  • .Net CoreRabbitMQ消息存储可靠机制
  • .Net Web项目创建比较不错的参考文章
  • .Net 垃圾回收机制原理(二)
  • @angular/cli项目构建--Dynamic.Form
  • @SpringBootApplication 包含的三个注解及其含义
  • [2016.7.Test1] T1 三进制异或
  • [Android]常见的数据传递方式
  • [Angular] 笔记 9:list/detail 页面以及@Output
  • [BT]小迪安全2023学习笔记(第29天:Web攻防-SQL注入)
  • [codevs 1288] 埃及分数 [IDdfs 迭代加深搜索 ]
  • [docker] Docker容器服务更新与发现之consul
  • [iBOT] Image BERT Pre-Training with Online Tokenizer
  • [Interview]Java 面试宝典系列之 Java 多线程
  • [iOS]-UIKit
  • [Java] 什么是IoC?什么是DI?它们的区别是什么?
  • [JS] 常用正则表达式集(一)
  • [leetcode] 61. 旋转链表
  • [LeetCode]—Copy List with Random Pointer 深度复制带“任意指针”的链表