使用版本控制系统最常见的工作流程就是修改代码,保存代码,共享代码。Git提供了一个简单的3步工作流,让你方便的完成这些操作。

1. 新建工作分支
2. 提交更改
3. 推送分支到中心存储库与团队成员共享

Git 工作流

按照以上3步操作,我们就可以开始日常的编码工作流了。下图中展示了这个工作流的示意:

下面,我们按照这3个步骤来完成一个典型的Git提交的创建过程:

1. 创建分支

创建分支之前你需要获取Git存储库,这部分请参考之前的内容。将命令行切换到存储库中的任意目录,然后执行以下命令:

>>> git branch

不带分支名称命令可以查看本地已经存在的分支

>>> git branch <分支名称>
>>> git checkout <分支名称>

带有分支名称的branch和checkout命令用于创建和切换分支,你也可以通过一个命令完成以上操作

>>> git checkout -b <分支名称>

执行完成后你会看到命令行的提示符发生变化,表示你已经切换到一个分支上进行工作了。

2. 提交代码到分支

首先通过cmder中的命令提示行确认你所处的分支是正确的,注意下图中的 (my-new-branch-2 -> origin) 这表示我们当前处于my-new-branch-2这条分支上,后面的origin是git远程存储库的一个标识,表示当前我们跟踪的是origin这个别名的远程存储库。

注:关于远程存储库我们在后面进阶篇会专门进行介绍,这里你只要知道这就是你克隆代码的那个存储库就够了。

在以上命令行状态下键入以下命令打开 Visual Studio Code,编辑文件并保存退出。

>>> code .

以上我们对2个文件进行了变更,a.txt是一个已经存在的文件,b.txt是我们刚刚新建的文件。以上我们保存文件并关闭vscode以后,可以通过以下命令查看当前工作目录中的变更

>>> git status

以上输出的内容中有2部分内容需要理解清楚

○ Changes not staged for commit:这部分列出的文件表示已经属于存储库的一部分,但是当前的改动并没有被暂存。
○ Untracked files: 这部分列出的文件还不属于存储库的一部分。

你会注意到在a.txt前面显示了modified,因为a.txt已经是存储库的一部分所以git可以跟踪到你对它的修改,但是对与b.txt git根本不知道你做了什么,它只知道这里有个文件还没有被git跟踪。

现在,我们需要将这两个文件“暂存”,做好提交准备。然后执行以下命令完成暂存

>>> git add --all
>>> git status

你也可以使用文件名或者通配符替换–all参数,只添加那些自己认为需要暂存的文件。

如果暂存错误,使用以下命令取消暂存。

>>> git reset HEAD

这时git已经将2个文件全部放入了暂存区,准备进行提交。这时你可以执行以下命令完成提交,git会对当前文件创建快照,形成版本记录。请执行

>>> git commit -m "my first git commit"

git commit 命令用于提交代码变更到git存储库,后面的-m参数由于给出你的提交注释,在git中提交注释是必选项,不能掠过。这其实是一个非常好的设计,我想你一定为了在svn代码库中看到一堆没有注释的变更骂过街。

完成 git commit 命令后,你的git中就已经保存了刚才所做的代码改动了。现在你可以继续编码,并在感觉必要的时候随时重复以上的过程保存自己的改动,就不用再担心会丢失代码了。

你还可以随时切换回到master分支,这个操作不会要求你更改目录,而在编辑器里面的代码会直接切换到master分支的代码状态。只要执行

>>> git checkout master

注意:当我完成切换的是时候,我们之前创建的b.txt从vscode中消失了,同时a.txt里面之前修改的内容也不见了。如果要找回改动,只要再切换回到刚才的分支即可。

3. 推送分支到中心存储库与团队成员共享

企业开发中推常见的场景就是团队协同,开发人员本地完成修改后需要共享给其他开发人员一起使用,这时我们可以利用中心存储库来完成这个操作。首先确保你处于自己希望共享的分支中,然后运行:

>>> git push origin my-new-branch-2

完成操作后,你的本地分支就被推送到中心存储库上了,这时其他开发人员就可以通过以下命令获取你的分支代码。

>>> git fetch
>>> git checkout my-new-branch-2

注意:git允许你在本地和远程使用不同的分支名称,这给予开发人员更多的自由度,但是有时候也会造成麻烦,比如可能你忘记了你本地分支已经在跟踪一条远程分支,不小心改错了代码。

为了能够更加清晰的标识分支的所有人,一般我们在建立分支的时候会通过前缀的方式来标识,使用特定格式的前缀可以让VSTS/TFS将你的前缀变成分支文件夹形式显示,便于管理。如下图,在创建分支的时候使用了 leixu/ 作为前缀,推送到服务器上以后就变成文件夹显示

你甚至可以设置多级文件夹,这样在团队比较大的时候管理起来就容易多了。

为何一定要使用分支?

为什么改动一定要放在分支中实现。这个与软件开发本身的特性有关系,软件开发过程本身是一个不确定的过程,没有人可以在代码写完之前预测出到底应该怎样写。这个与产品生产制造不同,产品生产制造之前,所有的工序,操作和零件都是确定的,因此我们可以清晰的规划如何完成制造过程,也可以将这个过程组织成流水线顺序执行(注意:这里的流水线特指制造业工厂中的生产流水线,与我们后面说的软件交付流水线不同)。软件的开发过程则完全是一个探索过程,开发人员需要经过多次失败的尝试才能最终找到正确的实现方式,这个过程需要多次修改代码,有时还可能会推翻从来。这种循环往复的过程越接近开发人员的日常编码,越接近最小的功能实现就越发频繁。因此,开发人员必须能够在不影响主干代码的情况下,自助的创建代码副本,在这个副本上完成以上尝试;同时,也需要兼顾代码主干上的变更,确保自己的改动的基准永远与整个团队对齐,否则就算写好了也无法与整个团队的工作集成。这个矛盾是所有配置管理策略要处理的核心矛盾,所有我们所遇到问题,各种复杂的分支策略以及后续的持续交付流水线的设计都是基于这个问题延展出来的,只不过在更加复杂的团队/产品/项目中,这个矛盾被乘各种复杂度被放大,因而需要我们提供更为复杂的配置管理流程来进行适应。

从这一点上稍微扩展一下,你就可以理解其实所有的配置管理流程的设计原则应该是“适应”而不是“控制”,找出最适合团队的流程,让流程为人服务是所有配置管理流程目标。也因为此,我们需要将配置管理流程视为一个变化的规则,它必须根据团队的情况适时改变,才能确保可用。

理解了以上2点内容,我们就知道为什么Git的工作一定要放入分支,而不是在主干上直接操作。如果代码变更直接进入master或者团队成员共享的分支,则会直接对生产环境或者团队成员共享的环境造成影响,在变更还未成熟稳定之前,最保险的做法就是尽量隔离的进行修改直到代码可以被其他成员或者某一环境接受的时候再合并进去。

虽然任何的配置管理工具都允许你创建分支,但是Git的以下2个特性决定了它超越其他任何配置管理工具成为团队的首选:

1. 轻量级分支:Git的分支非常轻,可以在瞬间完成创建,也可以随时被销毁;拉分支不会增加Git存储库的存储开销,只有当你提交修改的时候才会增量的增加相应的存储内容。
2. 同文件夹内切换分支:Git分支切换不需要切换文件夹,这样可以和开发工具更好的集成,开发人员可以快速的在不同分支间进行切换,甚至都不需要停止IDE里面的Debug进程。这让开发人员更加敏捷的进行尝试,更加快速的解决问题。
3. 本地分支:因为分布式的特点,Git分支不需要依赖服务器就可以完成。给予开发人员独立的,不依赖其他人就可以进行尝试的可能性。而在集中式配置管理工具中,任何分支的创建都必须是由配置管理员才能完成的工作,这大大降低了单个开发人员的效率。

采用集中式版本控制(CVCS)的系统并不是不能创建分支,但是由于分支过于沉重,开销太大,团队往往会选择只允许配置管理员才能执行这个操作,这就让开发人很受束缚。

注:当然,也正是因为以上这些优势,才让很多企业的大规模团队管理者对Git敬而远之,觉得它太过灵活。其实Git完全兼顾了大规模团队的管控要求,只是实现的方式与传统的配置管理工具不同而已,这一点我们会在第3部分中专门讨论。

小结

在这一篇中我们介绍了基本的Git编码工作流程,了解了这些你就可以开始使用Git进行日常的编码工作了。当然,既然Git推荐我们尽量使用分支来维护变更,那么就必须允许我们进行合并,这样才能最终完成团队开发的协作。这部分会在下一篇中进行介绍。

相关文章:

原文地址:http://devopshub.cn/2018/01/13/g4e-basic-04-git-repo/


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 

g4e基础篇#5 创建分支和保存代码相关推荐

  1. g4e基础篇#6 了解Git历史记录

    Git的版本历史记录采用了与传统集中式版本管理系统完全不同的方式进行组织,在刚开始使用Git的时候我们往往会不知所措,比如看到这样的历史记录. 看到这个七拐八拐的图形,你可能完全不知道它代表了什么.其 ...

  2. g4e基础篇#2 Git分布式版本控制系统的优势

    1. 基础篇: 为什么要使用版本控制系统 Git 分布式版本控制系统的优势 Git 安装和设置 初始化Git存储库(Repo) 起步 1 – 创建分支和保存代码 起步 2 – 了解Git历史记录 起步 ...

  3. g4e基础篇#1 为什么要使用版本控制系统

    本篇是Git企业开发者教程基础篇的第一篇 1. 基础篇: 为什么要使用版本控制系统 Git 分布式版本控制系统的优势 Git 安装和设置 初始化Git存储库(Repo) 起步 1 – 创建分支和保存代 ...

  4. g4e基础篇#4 了解Git存储库(Repo)

    Git 存储库看上去就是一个文件夹,只是在这个文件夹中不仅仅保存了所有文件的当前版本,也同时保存了所有的历史记录,这些额外的信息都保存在当前文件夹下面的.git子目录中.因为前面我们所描述的git跟踪 ...

  5. g4e基础篇#3 Git安装与配置

    现在你已经对Git有了最基本的了解,现在让我们开始动手开始安装和配置Git环境. Git工具包括Git命令行工具,图形化工具和服务器环境:在我们这个教程中,我们会使用以下软件配置我们的环境: • Wi ...

  6. github创建分支并提交代码至分支

    github创建分支并提交代码至分支 登录自己的github,进入自己的仓库,点击下图所示 然后创建新的分支,输入新的分支名,回车 然后默认是直接进入这个分支,也可以点击进入分支,然后在本地文件夹下克 ...

  7. 【GIT 基础篇六】分支管理(创建与合并)

    上篇我们整理了如何创建远程仓库,以及如何将本地文件上传至远程仓库,仓库创建好了,我们接下来就要准备开发了,对于使用git而言,通常的习惯就是一人一个分支,等测试无误再合并:又或者根据需求创建分支,整体 ...

  8. master分支删除文件_Git分支基础简介;创建分支;合并分支;删除分支;

    目录 为了演示:我们创建了一个本地仓库testBranch,一个远程仓库testBranchRe: 1.当我们创建一个本地仓库的时候,这个本地仓库中就会有一个主分支,即master分支: 2.每次提交 ...

  9. git创建分支,提交代码详细流程(保姆级)

    其实最基本的流程就是新建分支,在这个分支上改动代码,再提交上去,跟master分支合并. 1. 新建分支 首先,在你新建分支之前,你应该在master分支,并且要保证你当前的是最新代码,要不然就是找死 ...

最新文章

  1. mpvue 微信小程序_使用Vue.js开发微信小程序:开源框架mpvue解析
  2. 在Google Cloud Platform的K8上运行Fn函数
  3. 套接字编程---2(TCP套接字编程的流程,TCP套接字编程中的接口函数,TCP套接字的实现,TCP套接字出现的问题,TCP套接字多进程版本,TCP套接字多线程版本)
  4. 行政区域村级划分数据库_最新行政区划代码省市区三级 乡镇街道四级 村五级 数据库(2020年11月版 )...
  5. 分步骤演示如何使用Filter链拦截MyServlet的同一个请求
  6. echarts里面的参数解释_SPMSM控制:传统PI速度环参数的整定
  7. Excel--数据分列功能
  8. python中oxf2是多少_Python学习笔记[2]
  9. 自然语言处理----词干提取器
  10. plsqldev解决中文乱码问题
  11. 在别人电脑登录微信会【泄露隐私】,登录微信后一定要删除这个文件
  12. 计算机网络CDMA是什么,CDMA是什么
  13. 优先使用组合而不使用继承
  14. 投影幕尺寸参数对照表
  15. android 日语输入法,Android日语输入法Simeji使用示例
  16. Linux 命令(204)—— ss 命令
  17. 『贪心』阿狸和桃子的游戏
  18. php中的数据库操作和字符串操作session与cookie操作,php中的数据库操作和字符串操作session与cookie操作...
  19. 一个很好的看电子书的软件
  20. 横跨十年CPU架构回顾

热门文章

  1. 如何管理跨部门的沟通与协作?
  2. DOCKER存储驱动之DEVICE MAPPER简介
  3. JAVA-MyBatis ORM
  4. PowerTip of the Day from powershell.com上周汇总(六)
  5. 如何通过 C# 判断一个 路径 是本机还是远程 ?
  6. 微软推出 .NET 官方社区论坛
  7. Envoy实现.NET架构的网关(一)静态配置与文件动态配置
  8. Resharper 和 Rider 的奇淫技巧,你知道多少?
  9. 如何使用 C# 中的 ValueTuple
  10. 跟我一起学.NetCore之熟悉的接口权限验证不能少(Jwt)