问题描述
你好,我是 monorepos 世界的新手,我现在正在寻找不同的 monorepos 工具 我发现了两个有趣的工具 Nx(nrwl) 和 lerna 但我不明白这两个工具之间的真正区别所以任何帮助和感谢
解决方法
虽然两者都是处理单一存储库的绝佳工具,但它们的用途却大不相同。
差异
Lerna
专注于链接来自同一项目的多个包并管理 npm 发布,仅此而已。
Nx
更专注于管理多个包的开发工作流程。这意味着它可以为包提供脚手架,并且对于每个包,您可以定义有关如何运行和构建它们的配置,类似于 Webpack。
Nx
也可以同时产生多个进程。例如:前端和后端同时运行,无需打开两个不同的终端。类似于 docker-compose。
他们在哪里茁壮成长
Lerna
更适合具有多个包的开源项目(因为您可以轻松发布包)。
Nx
更适合处理具有多个包的复杂工作流。
如何选择
- 如果您不打算发布您的软件包,
Nx
可能更合适。 - 如果您当时确实打算发布,但没有复杂的工作流程,那么
Lerna
绝对是您要走的路。 - 如果您同时想要(发布和复杂的工作流程),似乎都不是很好,但您可能应该选择
Nx
,并手动管理发布。或者,也许,使用Lerna
并使用 Webpack 手动配置工作流程。
有人可能想知道您是否可以同时选择两者,但我认为它们不能很好地协同工作。在我写这篇文章的时候,Nx
似乎并不关心与 Lerna
的兼容性,它 Nx
仍然缺乏对轻松发布的支持。
关于术语的重要免责声明
- 我在这里使用了“包”这个名称,因为“包”是您可以在 Internet 上发布的内容(例如,在
NPM
- 节点 包 管理器中)。 -
Lerna
使用名称“project”作为所有包的包装文件夹。通常,一个 git 存储库是一个带有多个“Lerna 包”的“Lerna 项目”。 -
Nx
使用名称“project”来指定 Lerna 所说的“包”,并使用名称“workspace”来指定 Lerna 所说的“项目”(即,包含所有项目的包装文件夹) .