Git系列(二)——初步认识Git
前言
如果大家认为这个章节看得不太明白,太晕了可以直接跳过,继续看完后面内容再回来看就会豁然开朗了
一、初步认识Git
Git是当前先进的最主流的分布式控制系统,核心能力就是可以进行版本控制。说得更加直白一点,就是可以将你每次提交的代码的状态管理起来,会保存好这种状态信息,这就意味着你可以恢复到以前任意时刻的状态。同时它还支持跨区域多人协作编辑,是团队项目开发的必备基础。
二、Git基本概念术语
概念名称 | 描述 |
---|---|
头(HEAD) | HEAD类似于一个“指针”,指向的就是当前分支的最新版本 |
提交(Commit) | 将暂缓区变更内容提交到当前仓库的活动分支 |
推送(Push) | 將本地仓库的版本推送到服务端(远程)仓库 |
拉取(Pull) | 从服务端(远程)仓库获取更新到本地仓库,获取他人共享的更新。 |
获取(Fetch) | 从服务端(远程)仓库更新,和Pull一个作用,但是不会自动合并 |
冲突(Conflict) | 多人对同一文件副本进行操作进行修改,并将这些更改合并到仓库时就会出现多个版本的情况,内容修改各不相同,这时候我们就需要将修改的部分全部融合到一个版本去 |
合并(Merge) | 对冲突的文件进行合并操作,Git 会自动合并更改内容,会自动处理冲突内容等待提示信息 |
标签(Tags) | 指的是某个分支某个特定的时间点状态,可以直接理解为提交记录,标记一个版本号 |
分支(Branch) | 分支是从主线分离出来的“副本”,可以独立操作互不干扰,仓库初始化有一个默认主分支main ,2020年之前的默认分支为master |
工作区(Workspace) | 就是我们电脑看到的代码库目录,我们日常“搬砖”的地方 |
暂缓区(stage) | 用于*临时存放文件的修改,实际上就是一个.git 文件,保存列表信息 |
版本库/仓库(Repository) | Git管理仓库,记录文件/目录状态的地方,所有内容的修改记录都在这里 |
服务端/远程仓库(origin/remote) | 服务端的版本库,专用的Git服务器,为多人共享 提供服务器,push 指令把代码推送到服务器端版本库 |
本地仓库 | 用户机器上直接使用的版本库 |
三、工作区 / 暂缓区 / 仓库
流程理解
四、Git的基本流程
小明是一个刚刚毕业的大学生,被一家知名的互联网企业签下了,由于第一次参与企业级大型项目,所以对于复杂的 Git 工作流十分的不熟悉,于是公司的老员工们纷纷来帮助他。
小明先是打开了公司开源的 Git 仓库地址,并利用 Git 工具 clone 下来了项目的代码,但是一看到上百条分支就头晕了,于是老员工 Jack 拿出了上面那张 Git 基本工作流的图片来一一为他讲解,Jack 说:其实呢,之所以创建这么多的分支的原因就是为了方便基于老代码进行的优化和更新的新代码能够根据不同的变化占有一个分支,将一大个复杂的问题分类成一个个小的问题,从而下派给各个部门进行工作,这样不同的部门各自管理一条各自的分支,工作就井然有序啦!
小明说:哦,原来是这样,那这个图上这些分支的名字都代表什么含义呢?
这时另一名老员工 Smith 说:这张图呢是我们企业最初一张基本的 Git 工作流的图咯,现在已经非常复杂了,不过对于你初步理解整个流程是非常好的,那么这个Master分支,顾名思义就是我们的主分支啦,是我们所有部门整合起来的一个主分支,代表了我们项目整体的走向,每次一个子分支完成测试后就将其 merge 到 Master 分支然后再进行整体的测试,如果一个版本的功能已经完成全部测试,那么就将其发放到 Release 分支啦,也就是正式发行给大众的分支,就像咱们平时使用的某一款软件的一个版本更新一样(类比上图就相当于基于 Master 分支创建了一个 Develop 分支,然后 Develop 分支开发到一定程度后将其 merge 到 Release 分支和 Master 分支),那么图中的 HotFix 分支顾名思义就是处理一些突发 bug 的分支,进行快速修改再重新 Merge 到 Master 分支,Feature 分支就是代表一个个新功能的分支。
小明说:哦,原来如此,明白了,那我就利用手上的 Git 工具进行一下实践试试看咯!
另一名老员工小姐姐 Mary 说:嗯嗯,有什么问题可以继续问我们哦,哦对了,你有没有考虑过这样一种情况呢,如果在 Master 分支的某一个节点创建了一个子分支,并在子分支对文件 1 进行了修改,与此同时 Master 分支也对文件 1 进行了修改,然后子分支 Merge 到了 Master 分支,这时候怎么处理呐!
小明说:哦,这不是合并冲突嘛!通常我们就手动的查看冲突的内容,通过一些解决冲突的工具,比如 mergetool 或者是 IDE 中的一些插件,然后选择自己想要留下的那个文件的内容就可以啦!解决冲突之后再进行 Merge
大家露出了欣慰的表情,都回到了自己的工位。。。。。