编者按:开发人员每天都要在工作中使用GitHub或其他基于Git的工具。 GitHub是面向开源及私有软件项目的托管平台。 那么什么是GitHub?其中都有哪些关键的概念?如何使用GitHub才能提高工作效率?
本文编译自medium上原标题为A developer’s introduction to GitHub的文章。
GitHub是一个拥有数十亿行代码的网站,每天有数百万开发者聚集在一起,研究开源软件中存在的问题。
简而言之,它是为软件开发人员构建的平台,是围绕Git构建的。
为什么选择GitHub?
现在你知道了GitHub是什么,你可能会问为什么需要使用GitHub。
毕竟,GitHub由一家私人公司管理并且该公司通过托管代码获利。 那么为什么应该使用GitHub而不是像BitBucket或GitLab这样的平台呢?
除个人喜好和技术原因外,还有一个重要原因:每个人都在使用GitHub,因此其网络效应不可小觑。
主要的代码库已经随着时间的推移从其他版本控制系统迁移到Git,因为它更加便捷,并且GitHub投入了大量的努力来满足开源社区的需求。
所以今天,你在查找一些软件库时,99%的情况下会在GitHub上找到它。
除了开源代码之外,许多开发人员还在GitHub上托管私有存储库,因为平台很方便。
现在让我们了解一下开发人员需要知道的有关Git的概念。
GitHub Issues
Github Issues是世界上最受欢迎的bug跟踪系统之一。
项目的所有者可以利用它组织,标记和将issue与里程碑关联。
如果您在其他人管理的项目上打开某个issue,它将保持打开状态,直到您将其关闭(例如,如果您找到了问题所在)或者项目管理者关闭这个issue。
有时候你会得到一个明确的答案,而其他时候,这个issue将会被打开并标记出一些分类信息。 然后开发人员可以回到这个issue来解决问题或根据反馈改进代码库。
大多数开发人员不会免费管理在GitHub上发布的代码,因此您不能期望即时回复。 但是一些开放源代码库由那些围绕该代码提供服务的公司发布,它们会提供具有更多功能的版本或者使用基于插件的系统。 这些公司已经为开源项目付给开发人员工资。
社会编码
几年前,GitHub标志出现了社交编码。
这是什么意思,和GitHub有什么关系呢?
Follow
使用GitHub,您可以通过访问用户的个人资料并单击关注,或者通过单击软件库上的观看按钮来关注开发人员或软件库。
在这两种情况下,活动都会显示在您的dashboard中。关注用户或软件库跟Twitter上的关注不一样,你看不见人们说什么,而可以看到人们在做什么。
Star
GitHub的一大特色就是能够为软件库加星标。用户可以通过这个操作将其他软件库加入到已加星标的软件库列表中,这样用户可以关注自己感兴趣的项目并发现类似的项目。
这也是最重要的评级机制之一,因为软件库的星星越多,它通常就越受欢迎和重要。它在搜索结果中也会位于更突出的位置。
重大项目可能有数万颗星。
GitHub也有一个trending页面,它会推荐在特定时间段内(例如今天或本周或本月)获得最多星星的软件库。
Fork
项目最后一个重要的网络指标是fork的数量。
这是GitHub如何工作的关键,因为fork是Pull Request(PR)的基础,这是一个更改提议。一个人可能会fork您的软件库,进行一些更改,然后创建一个PR来要求您合并这些更改。
有时fork软件库的人可能永远不会要求你合并任何东西。他们可能会因为喜欢你的代码而fork你的软件库,并在上面添加一些他们不想合并到原始软件库的东西。用户还可以修复他们遇到的bug。
受欢迎=更好
总而言之,这些都是项目受欢迎程度的关键指标。 除了上述指标之外,最近一次提交的日期和作者参与issue跟踪系统的信息也是衡量软件库或软件可信度的标准之一。
PR(Pull Request)
在前一节中,我介绍了Pull Request(PR)是什么。 重申一下,一个人可能会fork你的软件库,做一些改变,然后创建一个PR来要求你合并这些改变。
一个项目可能有数百个PR,通常情况下,项目越受欢迎,它的PR越多,如React项目:
一旦一个人提交了PR请求,项目的核心维护者就会对其进行审查。
根据请求范围(更改次数,受更改影响的事件数量或涉及到的代码的复杂程度),维护人员可能需要不等的时间来确保更改与项目兼容。
一个项目可能有有关改进的明确时间表。维护人员希望用户用尽可能简单的方式介绍PR中的体系结构。
这就是说,PR并不总是被立马接受,并且可能不会被接受。
在我上面的例子中,软件库中有一个一年半前的PR。这在所有项目中都会发,很正常,可能是由于我上面提到的原因。
项目管理
除了issues(开发人员获得用户反馈的地方)外,GitHub界面还提供了少量项目管理功能。
其中之一是Projects。它在生态系统中是非常新的,也很少被使用,但它是帮助用户组织需要完成的问题和工作的看板。
Wiki可以被用作文档。另一个受欢迎的项目管理功能是里程碑。它是issue页面的一部分,您可以将问题分配给特定的里程碑,可能是发布目标。
说到发布,GitHub通过引入发布增强了Git的标签功能。
Git标签是特定commit的指针,如果完成时间一致,它可以帮助您回到之前版本的代码,并且无需引用特定的commit。
GitHub发布版建立在Git标签的基础上,代表代码的完整版本,也可能代表代码最终产品完整工作版本的Zip文件,发行说明和二进制资产。
尽管可以通过编程创建Git标签(例如,使用命令行git程序),但创建GitHub版本是手动过程,在GitHub UI上进行。用户可以利用GitHub创建一个新版本,并选择你想应用的标签。
比较commits
GitHub提供了很多处理代码的工具。
您可能最希望做的事情之一是将一个分支与另一个分支进行比较。 或者您可能希望将最新的commit与您当前使用的版本进行比较,以便随时查看更改。
用户可以利用GitHub比较视图执行此操作:只需在软件库名称末尾添加/compare即可。
例如,
在下图中,我将最新的React v15.x与最新v16.0.0-rc版本进行了比较,方便大家了解更改的内容。
该视图向您展示了两个版本(或标签或commits)之间的不同以及实际差异。
Webhooks和服务
GitHub提供了许多有助于开发人员工作流程的功能,例如webhook和服务。
Webhooks
当软件库中出现特定问题时,Webhook可以触发外部服务,例如,推送代码时,创建分支或删除标签。
当问题发生时,GitHub会给URL发送POST请求。
当我们从本地计算机推送更新时,此功能能ping远程服务器以从GitHub获取最新代码。
服务
GitHub服务和新的GitHub应用程序是第三方集成程序,可改善开发者的体验或为用户提供服务。
例如,您可以设置一个测试运行器,这样每次TravisCI推送新commits时,它可以自动运行测试。
您可以设置Continuous Integration来使用CircleCI。您也可以创建一个Codeclimate集成程序来分析代码并创建Technical Debt报告和测试覆盖率。
小结
GitHub是一个了不起的工具和服务平台,是当今开发人员可以利用的真正神器。本教程只是入门级,但在GitHub上工作是不容错过的。
原文作者:Flavio Copes
原文链接:
编译组出品。编辑:郝鹏程