Error Knowledge Base npm EPERM

npm ERR! code EPERM

npm hit EPERM because the operating system denied the filesystem operation, commonly due to permissions, locks, antivirus, or Windows file handling.

Fix it fast

Most likely: The operating system denied a file operation. The common causes are wrong ownership, a locked file, antivirus/sync tooling, or a global prefix/cache path the current user cannot write.

1. Confirm this is your error
npm ERR! code EPERM
npm ERR! errno EPERM
2. Check the cause
ls -la <failing-path>
npm config get cache
npm config get prefix
whoami
lsof +D <failing-directory>
3. Apply the safe fix
# Fix ownership for the project and npm cache when they are owned by the wrong user.
sudo chown -R $(whoami) .
sudo chown -R $(whoami) ~/.npm
npm install

# For global installs, use a user-writable prefix instead of sudo.
npm config set prefix ~/.npm-global
4. Verify it works
npm install
ls -la <failing-path>
Don't use unsafe shortcuts
  • Do not use sudo npm install inside a project as the normal fix.
  • Do not chown broad system paths like /usr or /usr/local without understanding the impact.
  • Do not ignore file locks from editors, watchers, antivirus, or sync tools.

What This Error Means

Read this as a precise clue about which part of the workflow broke first. Once you know the failing layer, the fix path gets much shorter.

How to Fix It

The fastest fixes here come from checking the immediate failing layer before you change anything unrelated. Make one correction at a time and re-test from the same environment.

Identify the path npm is failing on (look for the last referenced file path in the error output).

Avoid sudo npm install for project installs. It often causes mixed ownership inside node_modules.

Fix ownership of npm cache and project folder (example:sudo chown -R $(whoami) ~/.npm).

If the error is for global installs, use a user-writable prefix (example:npm config set prefix ~/.npm-global) and ensure PATH includes it.

Retry after cleaning local state when safe (common:remove node_modules and retry install).

Why It Happens

The current user does not have permission to write to the project folder, npm cache, or global prefix.

Verify the Fix

Re-run the original command and confirm the filesystem error no longer appears.

If this is a permission fix, confirm new files in node_modules are owned by the expected user.

Manual filesystem checks

Check ownership/permissions for the failing path:ls -la <path>

How npm writes files during install

This is the part worth understanding if the quick fix did not hold. It explains what npm is trying to do at the moment the error appears.

npm is reporting a failure at a specific layer of the workflow:local environment, configuration, remote service access, or artifact metadata.

The fastest path is to identify which layer broke first, then verify that layer directly instead of retrying the same high-level command and hoping for a different result.

Prevent It From Coming Back

To prevent this, keep npm cache and project directories owned by the build user, avoid running project installs as root unless you know exactly why you need it, and ensure CI runners have enough disk space and sensible file descriptor limits.

Docs and source code

github.com/npm/cli/blob/417daa72b09c5129e7390cd12743ef31bf3ddb83/workspaces/libnpmexec/lib/with-lock.js

Open-source npm CLI code reference tied to this error code. - GitHub

    try {
      await fs.mkdir(lockPath)
    } catch (err) {
      if (err.code !== 'EEXIST' && err.code !== 'EBUSY' && err.code !== 'EPERM') {
        throw err
      }

Need help or found a mistake? Contact RepoFlow support for questions.

Join our mailing list