NX-cloud: Cache node_modules when using Nx Agents #28269
Replies: 3 comments 1 reply
-
Hey @vorlonbuster, what agent launch template are you using? Are you using the preconfigured ones that we have defined here https://github.com/nrwl/nx-cloud-workflows/blob/main/launch-templates/linux.yaml, or something custom? All the predefined ones have a specific step where it caches node_modules, as defined like so:
The thing is that the predefined launch templates expect the base-branch name to be main. So if you are using that, and your base branch is If you're already using a custom launch template, do you have a cache step configured? |
Beta Was this translation helpful? Give feedback.
-
Similar problem here.
|
Beta Was this translation helpful? Give feedback.
-
Hi all! This should be fixed now. Can you please try again with these one of these options: - name: Restore Node Modules Cache
uses: 'nrwl/nx-cloud-workflows/v5/workflow-steps/cache/main.yaml'
inputs:
key: 'package-lock.json|yarn.lock|pnpm-lock.yaml'
paths: |
~/.npm
# or ~/.cache/yarn
# or .pnpm-store
base-branch: 'main' The docs have also been updated here. |
Beta Was this translation helpful? Give feedback.
-
Hi.
Recently our organization started using Nx agents in our CI to speed up things.
This lead to an unexpected problem.
Some backstory.
We are using font awesome for our icons, this means that npm install fetches packages from font awesome's npm registry (https://npm.fontawesome.com/). This is not a problem in itself. A token is required and all works well.
One clean npm install with no caching downloads roughly 50MB (I think, depends on what you have included in your project).
Font awesome measures bandwidth so these clean installs add up. Standard pro bandwidth limit is 4GB. This means that 80 clean install will reach that max limit and you must wait to the start of next month to succeed with new clean install.
80 installs are quit a lot and haven't been a problem for us at all. Specially as we cache node modules on our CI servers.
When we started using Nx Agents we reached that limit within a day.
It seems that the agents being spun up all do a clean npm install every time. Please correct me if I'm wrong here and there is a solution for this. (almost) Nothing would please me more.
We use between 3 and 9 agents every time the CI need to build/lint/test stuff depending on the size of the job. This usually happens on PR, nightly builds, deployment etc.
So if 10 developers do 1 PR each day and each PR use 6 agents on average this means 60 clean installs right there. 10 nightly app builds using 3 agents and voila -> we are over the limit.
So my question is this:
Is there any way of caching node modules when we're using Nx agents?
If yes, hoorah, hit me!
if no, do you plan on supporting it?
If yes, hoorah, when?
If no, (sad face) we must abandon Nx agents.
Regards
Morten
Beta Was this translation helpful? Give feedback.
All reactions