一、概述
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 的基本流程
-
在工作目录 (工作区) 中修改某些文件
-
对已修改文件作快照,并保存到暂存区域 git add .
-
将保存在暂存区的文件快照提交到版本库 git commit -m ""
-
查看提交历史 git log 1、创建本地空仓库 init:初始化当前目录为仓库,初始化后会自动将当前仓库设置为 master 创建本地仓库的条件是需要一个空目录,然后在空目录中初始化你的项目 (1)创建一个名为 test 的空项目
2、新建文件添加到本地仓库 add:将文件添加到缓存区 commit:提交到本地仓库 (1)新建文件并添加到缓存 (2)提交文件到仓库 使用-m命令来简写描述我们的信息,如果不使用-m,会调用终端的注释编 辑器来输入描述信息,而不建议使用注释编辑器,因为注释编辑器比较难 用,不舒服。
git commit 会为我们生成40位的哈希值,用于作为 id,并把刚刚用 git add 添加到提交缓存区里的文件提交到本地仓库中,便于我们回滚,至此,这个 文件就已经添加到本地仓库中了,同时本地仓库也迭代了一个版本。
3、查看历史提交信息