Lerna and Nx
Nrwl (the company behind the open source build system Nx) has taken over stewardship of Lerna. Nx is a build system developed by ex-Googlers and utilizes many of the techniques used by internal Google tools. Lerna uses Nx to detect packages in the workspace and dependencies between them. Lerna defers to Nx's powerful task runner to run scripts, allowing you to run them in parallel, cache results, and distribute them across multiple machines, all while ensuring that dependencies between packages are respected. For a complete list of which Lerna versions are compatible with which Nx versions, see the Lerna and Nx Version Matrix.
The following is a high level overview of what each tool provides. Lerna can continue to be used by itself, and adding Nx Cloud for free on top can dramatically improve what you're already doing.
Lerna
Features
- Version - Automatically increment versions of packages, generate changelog information, create Github releases etc.
- Publish - Automatically create tags and publish packages to package registries, such as npm
Cost
Free and open source
Set up
npm install lerna
npx lerna init
Nx
Features
- Run only tasks affected by a code change
- Run prerequisite tasks first
- Cache task results locally
- Visualize the project graph
- Nx Console - Visual Studio Code plugin
Cost
Free and open source
Set up
npx lerna add-caching
- Continue using Lerna as usual
Lerna defers to Nx's power task runner behind the scenes to detect task dependencies. Some options for lerna run
behave differently than in older versions of Lerna. See Using Lerna (Powered by Nx) to Run Tasks for more details on what differs from older versions of Lerna.
Nx Cloud
Features
- Share cached task results across the organization
- Distribute task execution efficiently across agent machines
Cost
Free for open source projects
For closed source repositories, the first 500 computation hours per month are free. Most repositories do not exceed this limit. $1 per computation hour after that.
Set up
npx nx connect-to-nx-cloud
nx generate @nrwl/workspace:ci-workflow
(or set up your CI manually)- Continue using Lerna as usual