市场很扫兴日本央行维持利率不变ETF年度采办方针增加一倍跳动财经
66
2024-11-05
老铁们,大家好,相信还有很多朋友对于bitbucket注册和bitbucket账号的相关问题不太懂,没关系,今天就由我来为大家分享分享bitbucket注册以及bitbucket账号的问题,文章篇幅可能偏长,希望可以帮助到大家,下面一起来看看吧!
本文目录
团队项目的Git分支如何管理?如何成为GitHub高手?团队项目的Git分支如何管理?Git是目前最流行的源代码管理工具。大量的软件项目由GitHub、Bitbucket和GitLab这样的云服务平台或是私有的Git仓库来管理。在使用Git时通常会遇到的一个问题是采用何种分支管理实践,即如何管理仓库中作用不同的各类分支。和软件开发中的其他实践一样,Git分支管理并没有普遍适用的最佳做法,而只有对每个团队和项目而言最适合的做法。简单来说,在项目
开发中使用多个分支会带来额外的管理和维护开销,但是多个分支对于项目的团队合作、新功能开发和发布管理都是有一定好处的。不同的团队可以根据团队人员组成和意愿、项目的发布周期等因素选择最适合的策略,找到最适合团队的管理方式。这里讲一下三种常见的Git分支管理方式。单主干
单主干的分支实践(Trunk-baseddevelopment,TBD)在SVN中比较流行。Google和Facebook都使用这种方式。trunk是SVN中主干分支的名称,对应到Git中则是master分支。TBD的特点是所有团队成员都在单个主干分支上进行开发。当需要发布时,先考虑使用标签(tag),即tag某个commit来作为发布的版本。如果仅靠tag不能满足要求,则从主干分支创建发布分支。bug修复在主干分支中进行,再cherry-pick到发布分支。图1是TBD中分支流程的示意图。
图1.TBD中的分支流程的示意图
由于所有开发人员都在同一个分支上工作,团队需要合理的分工和充分的沟通来保证不同开发人员的代码尽可能少的发生冲突。持续集成和自动化测试是必要的,用来及时发现主干分支中的bug。因为主干分支是所有开发人员公用的,一个开发人员引入的bug可能对其他很多人造成影响。不过好处是由于分支所带来的额外开销非常小。开发人员不需要频繁在不同的分支之间切换。
GitHubflow
GitHubflow是GitHub所使用的一种简单的流程。该流程只使用两类分支,并依托于GitHub的pullrequest功能。在GitHubflow中,master分支中包含稳定的代码。该分支已经或即将被部署到生产环境。master分支的作用是提供一个稳定可靠的代码基础。任何开发人员都不允许把未测试或未审查的代码直接提交到master分支。
对代码的任何修改,包括bug修复、hotfix、新功能开发等都在单独的分支中进行。不管是一行代码的小改动,还是需要几个星期开发的新功能,都采用同样的方式来管理。当需要进行修改时,从master分支创建一个新的分支。新分支的名称应该简单清晰地描述该分支的作用。所有相关的代码修改都在新分支中进行。开发人员可以自由地提交代码和push到远程仓库。
当新分支中的代码全部完成之后,通过GitHub提交一个新的pullrequest。团队中的其他人员会对代码进行审查,提出相关的修改意见。由持续集成服务器(如Jenkins)对新分支进行自动化测试。当代码通过自动化测试和代码审查之后,该分支的代码被合并到master分支。再从master分支部署到生产环境。图2是GitHubflow分支流程的示意图。
图2.Githubflow中的分支流程的示意图
GitHubflow的好处在于非常简单实用。开发人员需要注意的事项非常少,很容易形成习惯。当需要进行任何修改时,总是从master分支创建新分支。完成之后通过pullrequest和相关的代码审查来合并回master分支。GitHubflow要求项目有完善的自动化测试、持续集成和部署等相关的基础设施。每个新分支都需要测试和部署,如果这些不能自动化进行,会增加开发人员的工作量,导致无法有效地实施该流程。这种分支实践也要求团队有代码审查的相应流程。
git-flow
git-flow应该是目前流传最广的Git分支管理实践。git-flow围绕的核心概念是版本发布(release)。因此git-flow适用于有较长版本发布周期的项目。虽然目前推崇的做法是持续集成和随时发布。有的项目甚至可以一天发布很多次。随时发布对于SaaS服务类的项目来说是很适合的。不过仍然有很大数量的项目的发布周期是几个星期甚至几个月。较长的发布周期可能是由于非技术相关的因素造成的,比如人员限制、管理层决策和市场营销策略等。
git-flow流程中包含5类分支,分别是master、develop、新功能分支(feature)、发布分支(release)和hotfix。这些分支的作用和生命周期各不相同。master分支中包含的是可以部署到生产环境中的代码,这一点和GitHubflow是相同的。develop分支中包含的是下个版本需要发布的内容。从某种意义上来说,develop是一个进行代码集成的分支。当develop分支集成了足够的新功能和bug修复代码之后,通过一个发布流程来完成新版本的发布。发布完成之后,develop分支的代码会被合并到master分支中。
其余三类分支的描述如表1所示。这三类分支只在需要时从develop或master分支创建。在完成之后合并到develop或master分支。合并完成之后该分支被删除。这几类分支的名称应该遵循一定的命名规范,以方便开发人员识别。
表1.git-flow分支类型
对于开发过程中的不同任务,需要在对应的分支上进行工作并正确地进行合并。每个任务开始前需要按照指定的步骤完成分支的创建。例如当需要开发一个新的功能时,基本的流程如下:
从develop分支创建一个新的feature分支,如feature/my-awesome-feature。在该feature分支上进行开发,提交代码,push到远端仓库。当代码完成之后,合并到develop分支并删除当前feature分支。在进行版本发布和hotfix时也有类似的流程。当需要发布新版本时,采用的是如下的流程:
从develop分支创建一个新的release分支,如release/1.4。把release分支部署到持续集成服务器上进行测试。测试包括自动化集成测试和手动的用户接受测试。对于测试中发现的问题,直接在release分支上提交修改。完成修改之后再次部署和测试。当release分支中的代码通过测试之后,把release分支合并到develop和master分支,并在master分支上添加相应的tag。因为git-flow相关的流程比较繁琐和难以记忆,在实践中一般使用辅助脚本来完成相关的工作。比如同样的开发新功能的任务,可以使用gitflowfeaturestartmy-awesome-feature来完成新分支的创建,使用gitflowfeaturefinishmy-awesome-feature来结束feature分支。辅助脚本会完成正确的分支创建、切换和合并等工作。
如何成为GitHub高手?ArielCamus在Medium上介绍了每天使用Git和GitHub的重要性,还分享了三个帮助大家成为Git和GitHub高手的简单规则。
本文不会介绍如何创建GitHub简历或如何使用终端提交Git。我将解释每天使用Git和GitHub的重要性,尤其对于正在学习写代码的人。我还将分享并讨论三个简单的规则,你可以通过遵循这些规则,变成一个优秀的Git和GitHub使用者。
为什么Git和GitHub如此重要?
如果你正在学习编程,而且你的终极目标是获得一份软件开发的工作。在这种情况下,答案很简单:
学习Git和GitHub非常重要,因为99%的公司都会使用Git和GiHub。所以,学习使用Git和GitHub可以让你更容易被雇佣,并且能将你和初级开
发者区别开来。高级开发者之所以成为高级开发者,并不是因为他们更了解特定语言的语法,而是他们有和真实用户一起处理大型复杂项目和完成业务目标的经验。
当你仍在学习写代码阶段时,你很难获得这种经验。然而,获得现实世界经验的一个简单方法就是利用现实世界项目使用的工具和方法。Git和GitHub就是一个例子。
你还可以做的事情:远程结对编程、为开源做贡献、为你的简历构建专业设计网站。
即使你同意「掌握Git和GitHub有助于找工作」,你可能仍然会想:
「为什么Git和Github对公司如此重要?」
简而言之,Git允许团队以异步方式高效地为同一个项目贡献代码。这使得团队能够更好地协作,从而解决更大更复杂的问题。
Git是一个分布式版本控制系统,它还提供取消更改、创建代码分支、解决合并冲突等机制。这些都是非常有用的特性,可以解决每个软件团队每天都面临的特定问题和常见问题。Git是当今的主流解决方案。
另一方面,GitHub是Git之上的附加层,它为其他特定和常见问题提供解决方案,比如代码审查、pullrequest、问题管理/bug跟踪等等。
注:尽管Git是大多数公司的首选版本控制解决方案,但GitHub仍然有一些强大的竞争对手,比如GitLab和Bitbucket。但是,如果你知道如何使用GitHub,那么你就能驾轻就熟地使用GitLab或Bitbucket。
现在你已经了解了掌握Git和Github的重要性,接下来我们来看三个简单规则,它们可以让你在学习编写代码阶段,就轻松成为专业的Git和Github用户。
如何利用3条简单规则掌握Git和Github?
我是Microverse的创始人,Microverse是一所面向远程软件开发人员的学校,在你找到工作前完全免费使用。我们在22周计划中,不仅教学生如何编程,同时也会给他们大量的指导和构思,让他们在计划中获得实际经验。
为了成为专业的Git和Github用户,我们要求学生遵循以下三个规则。培训结束后,我们的学生应该能自然而然运用Git、GitHub、branch、合并请求和代码评审。
在讨论这三条简单规则前,请先完成以下任务:
如果你对Git和Github还不熟悉,请先从HubSpot上完成这个很棒的教程:https://product.hubspot.com/blog/git-github;
如果你还不了解GitHub流,你应该先学习它,因为我们后边会用到:https://guides.github.com/tion/flow/。
无需多言,三条能令你在学习编程阶段就能熟练掌握Git和Github的简单规则如下:
规则#1:为每个新项目创建一个Git仓库
规则#2:为每个新特性创建一个新分支
规则#3:使用PullRequest将代码合并到Master分支
即使你的项目非常简单或者你只是单独工作,但只要在每次编程时遵循这三条规则,你很快就可以成为Git和GitHub的使用高手。
我们会简单分析每条规则,以便你理解该如何做以及为什么这些规则很重要。
规则#1:为每个新项目创建一个Git仓库
第一条规则很简单,但
是养成习惯非常重要。每当你开始一个新项目时,如你的简历、学习项目、编程挑战的解决方案等等,你都应该创建一个新的Git仓库,并将其推送到GitHub上。拥有专用的repo是为你编写的每一行代码使用版本控制的第一步。使用版本控制是你加入公司、开始从事实际项目后的工作方式。及早学习并养成习惯。
注:如果使用终端比较麻烦,你无法在所有项目中使用Git,可以考虑使用Github桌面应用程序(https://desktop.github.com/)。
规则#2:为每个新特性创建一个新分支。
假设你希望在简历里构建一个新的「Contactme」部分/组件。那么为这个新特性创建一个专用的分支,给它一个有意义的名称(例如contact-me-section),并将所有代码提交给这个特定的分支。
如果你不知道何为分支,请返回到Github流(https://guides.github.com/guidetion/flow/),阅读我之前推荐的内容。
使用分支可以让你和团队成员以并行的方式处理不同的特性,同时将每个特性的代码与其他代码区分开来。这使得不稳定的代码不会轻易并到主代码库中。
即使你是团队中唯一的成员,一旦你真正开始工作,熟练使用特性分支会使GitHub流的过程变得轻而易举。
规则#3:使用PullRequest将代码合并到Master分支
默认情况下,每个仓库都从一个主分支开始。永远不要直接在主分支上进行改动。相反,你应该使用特性分支,并打开一个新的PR,将特性分支代码与主分支代码合并。
在现实工作中,会有人查看你的PullRequest,并在批准前进行代码审查。GitHub甚至会对你的代码进行自动测试,让你知道它是否有问题。如果你的代码与主分支代码之间存在合并冲突,你也会收到通知。例如,如果另一个开发人员推送到主分支的更改影响了你修改过的文件时,就会发生这种情况。
在代码经过审查、测试和批准之后,reviewer会允许你合并PullRequest,或者他们直接合并你的PullRequest。
即使你单独工作,也要习惯于创建Pullrequest,以便将更改合并到主分支。这是几乎所有开源项目使用的基本工作流程。如果你曾经贡献过某个项目,理解这三个规则将让你的贡献很容易被接受。
结语
如果你仍然感到困惑,那就慢慢来,记住这三条规则。不要试图去想「如何做」,而要专注于「做什么」和「为什么」。
一旦「做什么」和「为什么」清楚了,在时机成熟时你就能知道「如何做」了。重复这个过程2-3次,你就会对它们得心应手了。
文章到此结束,如果本次分享的bitbucket注册和bitbucket账号的问题解决了您的问题,那么我们由衷的感到高兴!