Skip to content
forked from pinojs/pino

🌲 super fast, all natural json logger

License

Notifications You must be signed in to change notification settings

karankraina/pino

This branch is 6 commits ahead of, 29 commits behind pinojs/pino:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

2684d4a Β· Oct 15, 2024
Jul 25, 2024
Jul 12, 2024
Jul 12, 2024
Oct 13, 2024
Mar 30, 2024
Jul 12, 2024
Oct 13, 2024
Oct 15, 2024
May 31, 2021
Jan 16, 2021
Jun 19, 2022
Jul 23, 2017
Apr 4, 2020
Apr 4, 2020
Jun 10, 2022
May 6, 2018
Jul 12, 2024
Jan 13, 2024
Apr 29, 2024
Jan 12, 2022
Jun 15, 2018
Jul 12, 2024
May 2, 2023
May 2, 2023
May 2, 2023
Jul 12, 2024
Feb 10, 2023
May 2, 2023
Sep 23, 2024
Jul 25, 2016
Jul 25, 2016
Jul 10, 2018
Aug 21, 2024
Aug 31, 2024
Aug 19, 2022
Apr 18, 2022

Repository files navigation

banner

pino

npm version Build Status js-standard-style

Very low overhead Node.js logger.

Documentation

Install

Using NPM:

$ npm install pino

Using YARN:

$ yarn add pino

If you would like to install pino v6, refer to https://github.com/pinojs/pino/tree/v6.x.

Usage

const logger = require('pino')()

logger.info('hello world')

const child = logger.child({ a: 'property' })
child.info('hello child!')

This produces:

{"level":30,"time":1531171074631,"msg":"hello world","pid":657,"hostname":"Davids-MBP-3.fritz.box"}
{"level":30,"time":1531171082399,"msg":"hello child!","pid":657,"hostname":"Davids-MBP-3.fritz.box","a":"property"}

For using Pino with a web framework see:

Essentials

Development Formatting

The pino-pretty module can be used to format logs during development:

pretty demo

Transports & Log Processing

Due to Node's single-threaded event-loop, it's highly recommended that sending, alert triggering, reformatting, and all forms of log processing are conducted in a separate process or thread.

In Pino terminology, we call all log processors "transports" and recommend that the transports be run in a worker thread using our pino.transport API.

For more details see our Transports⇗ document.

Low overhead

Using minimum resources for logging is very important. Log messages tend to get added over time and this can lead to a throttling effect on applications – such as reduced requests per second.

In many cases, Pino is over 5x faster than alternatives.

See the Benchmarks document for comparisons.

Bundling support

Pino supports being bundled using tools like webpack or esbuild.

See Bundling document for more information.

The Team

Matteo Collina

https://github.com/mcollina

https://www.npmjs.com/~matteo.collina

https://twitter.com/matteocollina

David Mark Clements

https://github.com/davidmarkclements

https://www.npmjs.com/~davidmarkclements

https://twitter.com/davidmarkclem

James Sumners

https://github.com/jsumners

https://www.npmjs.com/~jsumners

https://twitter.com/jsumners79

Thomas Watson Steen

https://github.com/watson

https://www.npmjs.com/~watson

https://twitter.com/wa7son

Contributing

Pino is an OPEN Open Source Project. This means that:

Individuals making significant and valuable contributions are given commit-access to the project to contribute as they see fit. This project is more like an open wiki than a standard guarded open source project.

See the CONTRIBUTING.md file for more details.

Acknowledgments

This project was kindly sponsored by nearForm. This project is kindly sponsored by Platformatic.

Logo and identity designed by Cosmic Fox Design: https://www.behance.net/cosmicfox.

License

Licensed under MIT.

About

🌲 super fast, all natural json logger

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 91.2%
  • TypeScript 8.1%
  • Other 0.7%