GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
LOGGING(7) LOGGING(7)

Logging - Why, What & How We Log

The npm CLI has various mechanisms for showing different levels of information back to end-users for certain commands, configurations & environments.

All logs are written to a debug log, with the path to that file printed if the execution of a command fails.

The default location of the logs directory is a directory named _logs inside the npm cache. This can be changed with the logs-dir config option.

For example, if you wanted to write all your logs to the current working directory, you could run: npm install --logs-dir=.. This is especially helpful in debugging a specific npm issue as you can run a command multiple times with different config values and then diff all the log files.

Log files will be removed from the logs-dir when the number of log files exceeds logs-max, with the oldest logs being deleted first.

To turn off logs completely set --logs-max=0.

loglevel

loglevel is a global argument/config that can be set to determine the type of information to be displayed.

The default value of loglevel is "notice" but there are several levels/types of logs available, including:

  • "silent"
  • "error"
  • "warn"
  • "notice"
  • "http"
  • "info"
  • "verbose"
  • "silly"

All logs pertaining to a level proceeding the current setting will be shown.

The log levels listed above have various corresponding aliases, including:

  • -d: --loglevel info
  • --dd: --loglevel verbose
  • --verbose: --loglevel verbose
  • --ddd: --loglevel silly
  • -q: --loglevel warn
  • --quiet: --loglevel warn
  • -s: --loglevel silent
  • --silent: --loglevel silent

foreground-scripts

The npm CLI began hiding the output of lifecycle scripts for npm install as of v7. Notably, this means you will not see logs/output from packages that may be using "install scripts" to display information back to you or from your own project's scripts defined in package.json. If you'd like to change this behavior & log this output you can set foreground-scripts to true.

The --timing config ⟨/using-npm/config#timing⟩ can be set which does a few things:

1.
Always shows the full path to the debug log regardless of command exit status
2.
Write timing information to a process specific timing file in the cache or logs-dir
3.
Output timing information to the terminal

This file contains a timers object where the keys are an identifier for the portion of the process being timed and the value is the number of milliseconds it took to complete.

Sometimes it is helpful to get timing information without outputting anything to the terminal. For example, the performance might be affected by writing to the terminal. In this case you can use --timing --silent which will still write the timing file, but not output anything to the terminal while running.

npm-notice

The npm CLI reads from & logs any npm-notice headers that are returned from the configured registry. This mechanism can be used by third-party registries to provide useful information when network-dependent requests occur.

This header is not cached, and will not be logged if the request is served from the cache.

The npm CLI makes a best effort to redact the following from terminal output and log files:

  • Passwords inside basic auth URLs
  • npm tokens

However, this behavior should not be relied on to keep all possible sensitive information redacted. If you are concerned about secrets in your log file or terminal output, you can use --loglevel=silent and --logs-max=0 to ensure no logs are written to your terminal or filesystem.

npm help config
June 2025 NPM@10.9.3

Search for    or go to Top of page |  Section 7 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.