Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

the difference between nx and Lerna ? (monorepos)

hello i'm in new in monorepos world and i'm now searching about different monorepos tools and i found two intersting tools Nx(nrwl) and lerna but i didn't understand the real differnce between these two tools so any help and thanks

like image 273
anis khalfaoui Avatar asked Apr 08 '21 08:04

anis khalfaoui


People also ask

What is NX Monorepos?

A monorepo is a single git repository that holds the source code for multiple applications and libraries, along with the tooling for them.

What can I use instead of Lerna?

Yarn, Apache Maven, Bit, Builder, and Bazel are the most popular alternatives and competitors to Lerna.

What is lerna used for?

Lerna is a tool to manage Monorepos with Git and npm, which automatically ties together all package versions used across your repository. Assume that you have multiple typescript projects in different repositories that have common dependencies.


1 Answers

Although both are great tools to work with mono repo, they're quite different in their purpose.

Differences

Lerna is focused on linking multiple packages from the same project and managing npm publishing, and that's about it.

Nx is more focused on managing development workflow for multiple packages. It means it can scaffold packages, and for every package, you can define configurations on how to run and build them, in a similar manner to Webpack.

Nx can also work to spawn multiple processes at once. For example: run frontend and backend at the same time, without the need to open two different terminals. Similar to docker-compose.

Where they thrive

Lerna fits better for open source projects with multiple packages (because you can easily publish your packages).

Nx fits better for handling complex workflows with multiple packages.

How to choose

  • If you don't intend to publish your packages, Nx might be a better fit.
  • If you do intend to publish then, but you don't have a complex workflow, Lerna is definitely the way to go.
  • If you want both (publish and complex workflow), neither one seems great, but you should probably choose Nx, and manage the publishing manually. Or, maybe, use Lerna and configure the workflow manually with Webpack.

Someone can wonder if you could choose both, but I don't think they can work well together. At the time I'm writing this, Nx doesn't seem to care about being compatible with Lerna, and it Nx still lacks support for easy publishing.

An important disclaimer about terminology

  • I used the name "package" here because "package" is what you can publish on the internet (for example, in the NPM - Node Package Manager).
  • Lerna uses the name "project" as the wrapper folder of all your packages. Usually, a git repository is a "Lerna project" with several "Lerna packages".
  • Nx uses the name "project" to designate what Lerna calls "packages", and uses the name "workspace" to designate what Lerna calls "project" (i.e., the wrapper folder which holds all the projects).
like image 174
daymannovaes Avatar answered Sep 17 '22 13:09

daymannovaes