Error Knowledge Base NPM EEXIST

npm ERR! code EEXIST

npm hit EEXIST because it tried to create a file or directory that already exists where npm expected to create a new one.

What This Error Means

npm hit EEXIST because it tried to create a file or directory that already exists where npm expected to create a new one.

How to Fix It

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

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

Why It Happens

The error output usually includes the path that failed, that path points to the real OS-level issue (permissions, disk, locks, or limits).

How to Verify

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

Look for the last referenced filesystem path in the error output and validate that path exists and is writable.

Examples

npm ERR! code EEXIST
npm ERR! errno EEXIST

Prevention Tips

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.

Ensure CI runners have enough disk space and sensible file descriptor limits.

Where This Can Be Triggered

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