monorepo
最近,我一直在谈论和讨论扩展代码共享的方法。 一个流行的主题是“ monorepo ”,即多包共享存储库。
将单独的程序包保存在一个存储库中对于代码共享很有用,因为它使团队可以共享项目的一部分供其他团队和项目使用,而无需建立和维护许多存储库的开销。
例如,设想一个组织,其中不同的前端团队希望与共享的React组件进行协作和合作。 为了支持这一点,他们建立了一个共享的React库(例如Pinterest的Gestalt或HP的Grommet )。
为了做到这一点,他们考虑采用“ monorepo ”。 将所有组件都放在一个存储库中,而每个组件都是自己的包。 这种“有用的邪恶”也使贡献,运行CI / CD和管理变更变得更加容易。
在这篇文章中,我将回顾并分享有关生态系统中最佳工具和解决方案的知识,以实现这一目标。 根据您的经验,随意发表评论并提出自己的见解和工具!
关于Bit的事情是,每个存储库已经是一个monorepo。
您不需要重构任何东西。 您不需要重组项目,设置不同的程序包,定义package.json
文件或其他任何内容。
相反,您只需要将Bit添加到存储库并共享组件。 由于Bit具有自动将组件与项目隔离的功能,包括其所有依赖关系以及更多功能,因此这成为可能。
在将Bit添加到存储库后的数分钟之内,可以共享数十个组件,以在Bit的中心中可用,在那里可以对其进行组织,共享和在线播放,然后与NPM和Yarn一起安装。
当您对存储库中的一个组件进行更改时,Bit将自动跟踪更改并识别将其用作依赖项的其他组件。 然后,如果您运行bit status
,则可以看到所有组件,因为它们的依赖关系已被修改,这些组件已被自动修改。
意思是,无需手动浏览package.json
文件来管理对依赖项的更改,因为Bit可以帮助您简化Monorepo的维护工作。
您还可以将Bit添加到库的版本管理(CI / CD)中,以使用所有更改来更新每个版本上的组件。 由于Bit可以运行,构建和测试组件,因此您可以快速了解所有内容的新状态。
PR可以直接制作到monorepo,也可以通过bit import
来制作,其他人可以直接从其最终项目中导入和开发组件。
总结起来,如果您有一个组件库要制作一个多包的monorepo,Bit可能是最快,最省力的方法。 它还提供了附加值,例如可发现性,在线社区等。
试试看 。
位之前的语义UI组件库。
具有位(0重构)的语义UI组件库。
与Bit共享的组件 。
package.json
文件。 Lerna是用于在单个存储库中管理多个软件包的工具。
使用Lerna,您可以重构您的存储库以在其中存储多个软件包,而Lerna允许您链接依赖项( lerna bootstrap)
并根据您的选择对它们进行单独或一起版本化(独立模式意味着每个子软件包都有自己的服务端并在其依赖项更新时相应地进行更新)。
my-lerna-repo/
package.json
packages/
package-1/
package.json
package-2/
package.json
Lerna自动执行monorepo中软件包的任务。 lerna run build
将在每个子软件包中运行npm run build
并且lerna publish
将所有软件包发布到npm并更新git标签等。然后,可以从NPM的注册表中安装软件包。
Lerna在开始时需要做一些工作,并且需要更多工作,但是这是将少量核心程序包保留在单个存储库中并将其独立发布到NPM的可靠方法。
一些开源项目使用Lerna处理核心程序包,包括Babel,Jest和Gatsby。 它在网络上有许多教程和帖子。 这对于在一个存储库中管理单个项目的多个部分特别有用,而每个部分本身都是独立的“微型项目”。
Babel与Lerna打包 。
lerna bootstrap
链接项目中的依赖lerna bootstrap
。 Lerna publish
发布所有NPM更新。 package.json
和环境会导致维护开销增加。 Lerna和Bit可以在单个存储库中一起玩。
例如,Lerna可用于管理核心软件包,而Bit可用于共享所有较小的组件。 Bit还提供了组件的可发现性,并减少了所需的重构和维护量。
两者还可以与Yarn工作区一起玩。 Bit将自动管理存储库中组件之间的依赖关系,而Lerna将帮助您处理更大的核心软件包,而Workspaces将帮助整合和优化存储库中外部软件包的安装。
Git是大多数开发团队的首选SCM。 它允许您将一个存储库作为另一个存储库的子目录 ,为整个项目创建一个工作树 ,并且一个项目可以使用另一个项目中的代码。
但是,对于大多数开发人员来说,Git子模块是一个痛苦的话题。
首先,它们仅在master
分支上工作。 其次,子模块会在项目之间创建高度耦合的代码,从而难以在跨仓库任务上进行合并和协作。 子模块存储库也不知道它是嵌套的,并且可能具有从属存储库。
有多种工具可提供围绕Submodule功能的附加自动化功能,例如git-subtree , gitslave , braid和giternal 。 这些工具试图改善子模块的某些可用性问题,但不受特定供应商的支持,并且具有不同的缺点。
关于Monorepos的讨论正在社区中蓬勃发展。 尽管大多数人都认同多仓库体系结构的优点,但是一些用例使维护和发布来自多个存储库的多个软件包变得非常困难。 特别是在使用共享库时。
为了简化这一过程,生态系统中出现了新的工具。 从Lerna可以自动进行设置,以围绕在单个存储库中保存和发布较大的软件包,到Bit可以将组件库的经验提升到一个新的水平,而全力以赴,并获得所有好处。
最重要的是,共享代码既涉及技术,也涉及人员。 您和您的团队必须专注于编写可重用的代码,以模块化的方式进行思考,并鼓励交流和效率。 感谢您的阅读,请随时在下面发表评论并提出任何问题。 干杯
翻译自: https://hackernoon.com/4-ways-to-go-monorepo-in-2019-ea5d19fc1f08
monorepo