作者:布加迪
很多人问我:“我的编程项目应使用哪个分布式版本控制系统?GitHub还是GitLab?”这个问题不好回答。
首先,您真需要分布式版本控制系统(VCS)吗?VCS又叫源代码管理(SCM)系统,旨在让多个开发人员、设计人员和团队成员轻松地处理同一项目。它确保每个人可以访问同样的最新代码,并跟踪修改。
说起来容易做起来难。
这就是为什么Linus Torvalds将Git视为他的另一项伟大发明。Git免费、开源且快速。比之前的系统更胜一筹,比如Apache Subversion、并发版本系统(CVS)、Perforce和Rational ClearCase。这么多VCS服务的名称中含有“Git”是有道理的。
当然,您可以在自己的服务器上单独使用 Git。如果只是在内部开发程序,只需要本地Git实例。您还可以将Git用作自己的服务器上或云上的集中式VCS。如果可以自行构建VCS服务,无需订阅。使用该模式,您可以与遍布世界各地的团队和合作伙伴轻松地开发项目。
然而,如果您确实需要托管Git服务的额外功能,可以关注一下GitHub和GitLab。
GitHub是最古老的服务。它由Chris Wanstrath、P. J. Hyett、Tom Preston-Werner和Scott Chacon在2008年2月使用Ruby on Rails开发而成。由于先发优势,GitHub成了许多开源代码存储库的大本营。
后来出现了GitLab;乌克兰开发人员Dmitriy Zaporozhets和Valery Sizov于2011年创建了GitLab。一开始,GitLab就被设计成了代码存储库服务和一组协作工具。
相似之处这两者颇为相似。两者都在Linux服务器上运行,都随带问题单跟踪器,都提供广泛的第三方集成和导入工具。
它们还都为高级开发人员提供命令行界面(CLI),为新手程序员提供基于Web的界面。拿GitLab来说,用户界面使用GitLab自己的Pajamas设计系统(用Vue.js编写)。GitHub的用户界面Desktop可作为Windows或macOS程序来使用。您现在还可以将Visual Studio与GitHub一起使用。
虽然两者都支持开源,但存储库本身使用混合编程模式。GitLab使用开放核心业务方法。在此模式中,GitLab社区版保持免费开源,而GitLab企业版拥有更多功能并提供支持。至于GitHub,虽然其代码含有一些开源代码,但它不是一个开源项目。
不过从根本上说,两者都提供基于Web的存储库(附有基于Git的开源代码管理)和远程存储库的本地文件更改。如果您只想要基本的Git功能,别人负责确保Git正常运行,这两种服务都适合你。
当然,有些人仍不喜欢GitHub,因为微软在2018年收购了它。对一些人来说,微软永远是邪恶帝国,无论微软如何表明它现在支持开源方法和软件,或者无论微软首席执行官Satya Nadella怎么说他喜欢Linux。话虽如此,这从来不是一个很大的因素。虽然当时一些用户确实离开GitHub、转投GitLab和Atlassian BitBucket,但不像一些人预期的那样大批用户外流。
GitHub显然是VCS界的巨头。据编程工具公司JetBrains声称,77%的开发人员常使用GitHub,而只有40%的开发人员常使用GitLab、仅25%的开发人员常使用BitBucket。
差异之处主要区别在于,GitLab内置了持续集成/持续交付(CI/CD)和DevOps工作流程。GitHub让您可以使用自己选择的CI/CD工具,但需要自行集成。GitHub用户通常使用第三方CI程序,比如Jenkins、CircleCI或TravisCI。
另一个重要区别是,GitHub注重速度,而GitLab注重可靠性。具体来说,GitHub倡导将新分支与主分支合并。这样一来,您已经准备好了快速部署;万一出了岔子,又可以迅速修复旧版本。
在GitLab的工作流程中,您创建主分支之外的多个稳定分支。起码您会有生产级和预生产级稳定分支。这意味着要有多步骤测试过程。一接到合并请求只审查一次代码是不够的。
另一大区别是,GitLab提供了完整的软件开发解决方案。它自称是完整的DevOps平台不无道理。话虽如此,GitLab确实提供与一些第三方程序和平台的集成,比如Jira、Microsoft Teams、Slack、Gmail及其他许多应用程序和平台。
另一方面,GitHub在其自己的程序内提供的服务较少,但提供了与许多外部程序和服务集成的方法。这包括GitHub竭力与该服务集成的软件和通过GitHub Marketplace可享用的其他数百个程序。
价格两种服务都提供免费方案,随带无限的公共和私有存储库。如果您是个人程序员或有支小团队,应该足以满足需要。但是如果贵公司靠编程吃饭,就需要更高级的解决方案。
GitHub和GitLab的价格很难比较。建议从它们的免费方案入手,了解自己的工作流程在每个平台上如何运行,然后考虑订阅最适合自己的那种方案。
订阅费应该是您最不关心的问题。我用过这两种服务,就我的小规模编程而言,它们用起来都极好。
GitLab的Premium方案是每个用户每月收费19美元,而功能齐全的Ultimate方案每月收费99美元。至于GitHub,Team方案是每个用户每年40美元,而Enterprise方案是每个用户每年200美元。不过您可能会发现无论最终订阅哪种服务,都需要支付额外费用。
别让价格成为指导因素。真正重要的是,哪一个会为您提供开发软件所需的工具和服务。
原文标题:GitHub vs GitLab: The key differences,作者:Steven Vaughan-Nichols
来源: 51CTO