Unknown Local Cache Error
This document will explain why the following errors happen and how to address them.
1NX Invalid Cache Directory for Task "myapp:build"
2
3The local cache artifact in ".nx/cache/nx/786524780459028195" was not generated on this machine.
4As a result, the cache's content integrity cannot be confirmed, which may make cache restoration potentially unsafe.
5If your machine ID has changed since the artifact was cached, run "nx reset" to fix this issue.
6Read about the error and how to address it here: https://nx.dev/troubleshooting/unknown-local-cache
71NX Unrecognized Cache Artifacts
2
3Nx found unrecognized artifacts in the cache directory and will not be able to use them.
4Nx can only restore artifacts it has metadata about.
5Read about this warning and how to address it here: https://nx.dev/troubleshooting/unknown-local-cache
6Nx Tracks Cache Source
Nx can cache tasks, which can drastically speed up your CI and local builds. However, this comes with the potential risk of "cache poisoning", where cache artifacts could be intentionally or inadvertently overwritten. If another user executes a task that matches the hash of the tainted artifact, they could retrieve the corrupted artifact and use it as the outcome of the task. Nx and Nx Cloud contain several safeguards to minimize the likelihood of cache poisoning or, in the case of Nx Cloud, completely prevent it.
The errors above are some of these safeguards.
Nx trusts the local cache. If you executed a task and stored the corresponding cached artifact on your machine, you can safely restore it on the same machine without worrying about cache poisoning. After all, in order to tamper with the cache artifact, the actor would need access to the machine itself.
However, when artifacts in the local cache are created by a different machine, we cannot make such assumption. By default, Nx will refuse to use such artifacts and will throw the "Invalid Cache Directory" error or "Unrecognized Cache Artifacts" error.
Your MachineId Has Changed
Upgrading your computer's hardware may alter its Machine ID, yielding one of the errors above. To fix it execute nx reset to remove all the cache directories created under the previous Machine ID. After doing so, you should no longer see the error.
You Share Cache with Another Machine Using a Network Drive
When using the legacy file system cache (deprecated in Nx 20), you can prefix any Nx command with NX_REJECT_UNKNOWN_LOCAL_CACHE=0 to ignore the errors ( e.g., NX_REJECT_UNKNOWN_LOCAL_CACHE=0 nx run-many -t build test). This is similar to setting NODE_TLS_REJECT_UNAUTHORIZED=0 to ignore any errors stemming form self-signed certificates. Even though it will make it work, this approach is discouraged.
Storing Nx's local cache on a network drive presents security risks, so we prevent you from doing so. When a network drive is shared, every CI run has access to all the previously created Nx cache artifacts. Hence, it is plausible for every single artifact - for every single task hash - to be accessed without leaving any trace. This is possible due to the network drive's capability to allow overwrites.
How Nx Replay Makes Sure Sharing Cache is Safe
Nx Replay, the Nx Cloud hosted remote cache, does the following things to make sharing the cache safe:
- Immutable Artifacts: Nx Cloud allows you to create and store new artifacts without the ability to override the existing ones. This prevents any possibility of poisoning an existing artifact. This is achieved by managing the cache using short-lived signed URLs. 
- Artifact Accessibility: Nx Cloud provides access to the cache artifact specifically for the task that is currently being executed. It restricts the ability to list all cache artifacts. 
- Visibility Control: Nx Cloud comes with options to manage the visibility of your cache artifacts. For instance, the cache artifacts created in - mainmight be accessible by anyone across any branch, whereas the artifacts created in your PR could be shared only within your PR runs.
- Access Token Traceability: Nx Cloud keeps a record of the access token used to create a cache artifact. In case an access token gets compromised it can be easily removed, in turn deleting all the cache artifacts that were created using it.