是否曾经感觉您的代码库分散在一百万个不同的存储库中?这就是 Polyrepo 的生命周期,它是管理软件开发的传统方式。但如果有更好的方法呢?进入 monorepo,这是一个容纳您所有项目和库的巨型存储库。
本文深入探讨了 monorepos 的世界,探讨了它们的优点和缺点,并介绍了 NX,这是一个专门为管理这些代码天堂而构建的强大工具。
想象一个世界,每个开发团队都有自己的代码王国——每个项目都有一个单独的存储库。这就是 Polyrepo 的本质。虽然它提供了自主权(每个团队做出自己的决定),但它可能会导致孤立。一个项目中的更改可能会破坏另一个项目,仅仅是因为它们没有一起测试。
Monorepos 翻转这个脚本。它们将您的所有代码集中在一个屋檐下,促进协作并确保每个人都在同一页面上(字面意思是在同一个存储库中)。但是等等,这听起来不是很混乱吗?不完全是。 Monorepos 允许项目之间定义明确的关系,即使在一个大代码库中也能保持事物井井有条。
但是在你跳槽到 monorepo 之前,请记住——它并不适合所有人。它最适合拥有共享代码库并高度重视协作的组织。
不要将 monorepos 与 monolith 混淆。单体应用是巨大的、紧密耦合的应用程序,一切都交织在一起。另一方面,Monorepos 可以容纳独立的、松散耦合的项目。将其视为一个装满书籍的图书馆 - 每本书都是一个项目,但它们都整齐地组织在同一个书架上(单一仓库)。
所以,您决定探索 monorepo 世界。这就是 NX 的用武之地。它是一个构建系统,专为应对管理这些大规模代码库的独特挑战而设计。 NX 拥有一个功能工具箱,可让您的 monorepo 顺利运行:
Monorepos 为传统的 Polyrepo 方法提供了一种引人注目的替代方案,促进协作并降低破坏性变更的风险。 NX 及其管理工具套件使您能够充分利用 monorepo 模型。
但是,请记住 - monorepos 并不是一种万能的解决方案。在进行切换之前,请考虑您的团队结构和开发风格。但如果协作和简化的工作流程是您的目标,那么由 NX 管理的单一存储库可能就是解锁新水平的开发效率的关键。