Logs are an important part of observability. When something went wrong, logs help with the investigation and understanding of what happened. One of th

On log levels

submited by
Style Pass
2025-01-03 09:30:06

Logs are an important part of observability. When something went wrong, logs help with the investigation and understanding of what happened.

One of the most common problems is inconsistent use of log levels. If that’s the case, filtering by log level is almost useless and logs become hard to read.

Defining and documenting log levels helps maintain consistency. Everyone working on the project should find the definitions one way or another. In Lighthouse, for example, there’s a logUtils.ts file which includes the documentation at the top and the defines log levels within each respective log function.

npm defines log levels as "silent", "error", "warn", "notice", "http", "timing", "info", "verbose", "silly".

There’s not one right system. The most obvious difference is the number of log levels. RFC 5424 defines 8 levels, npm has 9, other projects use more, and some use fewer.

Leave a Comment