diff --git a/docs/transports.md b/docs/transports.md index 83d052030..7e0295476 100644 --- a/docs/transports.md +++ b/docs/transports.md @@ -410,24 +410,24 @@ PRs to this document are welcome for any new transports! ### Pino v7+ Compatible ++ [@axiomhq/pino](#@axiomhq/pino) + [@logtail/pino](#@logtail/pino) -+ [pino-elasticsearch](#pino-elasticsearch) -+ [pino-pretty](#pino-pretty) -+ [pino-loki](#pino-loki) -+ [pino-seq-transport](#pino-seq-transport) -+ [pino-sentry-transport](#pino-sentry-transport) ++ [@macfja/pino-fingers-crossed](#macfja-pino-fingers-crossed) + [pino-airbrake-transport](#pino-airbrake-transport) -+ [pino-datadog-transport](#pino-datadog-transport) -+ [pino-slack-webhook](#pino-slack-webhook) + [pino-axiom](#pino-axiom) -+ [pino-opentelemetry-transport](#pino-opentelemetry-transport) -+ [@axiomhq/pino](#@axiomhq/pino) ++ [pino-datadog-transport](#pino-datadog-transport) + [pino-discord-webhook](#pino-discord-webhook) ++ [pino-elasticsearch](#pino-elasticsearch) ++ [pino-hana](#pino-hana) + [pino-logfmt](#pino-logfmt) ++ [pino-loki](#pino-loki) ++ [pino-opentelemetry-transport](#pino-opentelemetry-transport) ++ [pino-pretty](#pino-pretty) ++ [pino-seq-transport](#pino-seq-transport) ++ [pino-sentry-transport](#pino-sentry-transport) ++ [pino-slack-webhook](#pino-slack-webhook) + [pino-telegram-webhook](#pino-telegram-webhook) + [pino-yc-transport](#pino-yc-transport) -+ [@macfja/pino-fingers-crossed](#macfja-pino-fingers-crossed) -+ [pino-hana](#pino-hana) ### Legacy @@ -455,6 +455,34 @@ PRs to this document are welcome for any new transports! + [pino-websocket](#pino-websocket) + +### @axiomhq/pino + +[@axiomhq/pino](https://www.npmjs.com/package/@axiomhq/pino) is the official [Axiom](https://axiom.co/) transport for Pino, using [axiom-js](https://github.com/axiomhq/axiom-js). + +```javascript +import pino from 'pino'; + +const logger = pino( + { level: 'info' }, + pino.transport({ + target: '@axiomhq/pino', + options: { + dataset: process.env.AXIOM_DATASET, + token: process.env.AXIOM_TOKEN, + }, + }), +); +``` + +then you can use the logger as usual: + +```js +logger.info('Hello from pino!'); +``` + +For further examples, head over to the [examples](https://github.com/axiomhq/axiom-js/tree/main/examples/pino) directory. + ### @logtail/pino @@ -462,6 +490,56 @@ The [@logtail/pino](https://www.npmjs.com/package/@logtail/pino) NPM package is [Quick start guide ⇗](https://betterstack.com/docs/logs/javascript/pino) + +### @macfja/pino-fingers-crossed + +[@macfja/pino-fingers-crossed](https://github.com/MacFJA/js-pino-fingers-crossed) is a Pino v7+ transport that holds logs until a log level is reached, allowing to only have logs when it matters. + +```js +const pino = require('pino'); +const { default: fingersCrossed, enable } = require('@macfja/pino-fingers-crossed') + +const logger = pino(fingersCrossed()); + +logger.info('Will appear immedialty') +logger.error('Will appear immedialty') + +logger.setBindings({ [enable]: 50 }) +logger.info('Will NOT appear immedialty') +logger.info('Will NOT appear immedialty') +logger.error('Will appear immedialty as well as the 2 previous messages') // error log are level 50 +logger.info('Will NOT appear') +logger.info({ [enable]: false }, 'Will appear immedialty') +logger.info('Will NOT appear') +``` + + +### pino-airbrake-transport + +[pino-airbrake-transport][pino-airbrake-transport] is a Pino v7+ compatible transport to forward log events to [Airbrake][Airbrake] +from a dedicated worker: + +```js +const pino = require('pino') +const transport = pino.transport({ + target: 'pino-airbrake-transport', + options: { + airbrake: { + projectId: 1, + projectKey: "REPLACE_ME", + environment: "production", + // additional options for airbrake + performanceStats: false, + }, + }, + level: "error", // minimum log level that should be sent to airbrake +}) +pino(transport) +``` + +[pino-airbrake-transport]: https://github.com/enricodeleo/pino-airbrake-transport +[Airbrake]: https://airbrake.io/ + ### pino-applicationinsights The [pino-applicationinsights](https://www.npmjs.com/package/pino-applicationinsights) module is a transport that will forward logs to [Azure Application Insights](https://docs.microsoft.com/en-us/azure/azure-monitor/app/app-insights-overview). @@ -474,6 +552,24 @@ $ node foo | pino-applicationinsights --key blablabla For full documentation of command line switches read [README](https://github.com/ovhemert/pino-applicationinsights#readme) + +### pino-axiom + +[pino-axiom](https://www.npmjs.com/package/pino-axiom) is a transport that will forward logs to [Axiom](https://axiom.co). + +```javascript +const pino = require('pino') +const transport = pino.transport({ + target: 'pino-axiom', + options: { + orgId: 'YOUR-ORG-ID', + token: 'YOUR-TOKEN', + dataset: 'YOUR-DATASET', + }, +}) +pino(transport) +``` + ### pino-azuretable The [pino-azuretable](https://www.npmjs.com/package/pino-azuretable) module is a transport that will forward logs to the [Azure Table Storage](https://azure.microsoft.com/en-us/services/storage/tables/). @@ -522,6 +618,87 @@ $ node foo | pino-datadog --key blablabla For full documentation of command line switches read [README](https://github.com/ovhemert/pino-datadog#readme) + +### pino-datadog-transport + +[pino-datadog-transport][pino-datadog-transport] is a Pino v7+ compatible transport to forward log events to [Datadog][Datadog] +from a dedicated worker: + +```js +const pino = require('pino') +const transport = pino.transport({ + target: 'pino-datadog-transport', + options: { + ddClientConf: { + authMethods: { + apiKeyAuth: + } + }, + }, + level: "error", // minimum log level that should be sent to datadog +}) +pino(transport) +``` + +[pino-datadog-transport]: https://github.com/theogravity/pino-datadog-transport +[Datadog]: https://www.datadoghq.com/ + +#### Logstash + +The [pino-socket][pino-socket] module can also be used to upload logs to +[Logstash][logstash] via: + +``` +$ node app.js | pino-socket -a 127.0.0.1 -p 5000 -m tcp +``` + +Assuming logstash is running on the same host and configured as +follows: + +``` +input { + tcp { + port => 5000 + } +} + +filter { + json { + source => "message" + } +} + +output { + elasticsearch { + hosts => "127.0.0.1:9200" + } +} +``` + +See to learn +how to setup [Kibana][kibana]. + +For Docker users, see +https://github.com/deviantony/docker-elk to setup an ELK stack. + + +### pino-discord-webhook + +[pino-discord-webhook](https://github.com/fabulousgk/pino-discord-webhook) is a Pino v7+ compatible transport to forward log events to a [Discord](http://discord.com) webhook from a dedicated worker. + +```js +import pino from 'pino' + +const logger = pino({ + transport: { + target: 'pino-discord-webhook', + options: { + webhookUrl: 'https://discord.com/api/webhooks/xxxx/xxxx', + } + } +}) +``` + ### pino-elasticsearch @@ -572,6 +749,31 @@ $ node your-app.js | pino-gelf log [gelf]: https://docs.graylog.org/en/2.1/pages/gelf.html [graylog]: https://www.graylog.org/ + +### pino-hana +[pino-hana](https://github.com/HiImGiovi/pino-hana) is a Pino v7+ transport that save pino logs to a SAP HANA database. +```js +const pino = require('pino') +const logger = pino({ + transport: { + target: 'pino-hana', + options: { + connectionOptions: { + host: , + port: , + user: , + password: , + }, + schema: , + table: , + }, + }, +}) + +logger.info('hi') // this log will be saved into SAP HANA +``` +For more detailed information about its usage please check the official [documentation](https://github.com/HiImGiovi/pino-hana#readme). + ### pino-http-send @@ -611,33 +813,20 @@ Tags and other metadata can be included using the available command line options $ node index.js | pino-logflare --key YOUR_KEY --source YOUR_SOURCE ``` - -### pino-mq - -The `pino-mq` transport will take all messages received on `process.stdin` and send them over a message bus using JSON serialization. - -This is useful for: - -* moving backpressure from application to broker -* transforming messages pressure to another component - -``` -node app.js | pino-mq -u "amqp://guest:guest@localhost/" -q "pino-logs" -``` - -Alternatively, a configuration file can be used: + +### pino-logfmt -``` -node app.js | pino-mq -c pino-mq.json -``` +[pino-logfmt](https://github.com/botflux/pino-logfmt) is a Pino v7+ transport that formats logs into [logfmt](https://brandur.org/logfmt). This transport can output the formatted logs to stdout or file. -A base configuration file can be initialized with: +```js +import pino from 'pino' +const logger = pino({ + transport: { + target: 'pino-logfmt' + } +}) ``` -pino-mq -g -``` - -For full documentation of command line switches and configuration see [the `pino-mq` README](https://github.com/itavy/pino-mq#readme) ### pino-loki @@ -661,24 +850,33 @@ pino(transport) For full documentation and configuration, see the [README](https://github.com/Julien-R44/pino-loki). - -### pino-papertrail -pino-papertrail is a transport that will forward logs to the [papertrail](https://papertrailapp.com) log service through an UDPv4 socket. + +### pino-mq -Given an application `foo` that logs via pino, and a papertrail destination that collects logs on port UDP `12345` on address `bar.papertrailapp.com`, you would use `pino-papertrail` -like so: +The `pino-mq` transport will take all messages received on `process.stdin` and send them over a message bus using JSON serialization. + +This is useful for: + +* moving backpressure from application to broker +* transforming messages pressure to another component ``` -node yourapp.js | pino-papertrail --host bar.papertrailapp.com --port 12345 --appname foo +node app.js | pino-mq -u "amqp://guest:guest@localhost/" -q "pino-logs" ``` +Alternatively, a configuration file can be used: -for full documentation of command line switches read [README](https://github.com/ovhemert/pino-papertrail#readme) +``` +node app.js | pino-mq -c pino-mq.json +``` - -### pino-pg -[pino-pg](https://www.npmjs.com/package/pino-pg) stores logs into PostgreSQL. -Full documentation in the [README](https://github.com/Xstoudi/pino-pg). +A base configuration file can be initialized with: + +``` +pino-mq -g +``` + +For full documentation of command line switches and configuration see [the `pino-mq` README](https://github.com/itavy/pino-mq#readme) ### pino-mysql @@ -699,6 +897,48 @@ For full documentation and command line switches read the [README][pino-mysql]. [MariaDB]: https://mariadb.org/ [JSONDT]: https://dev.mysql.com/doc/refman/8.0/en/json.html + +### pino-opentelemetry-transport + +[pino-opentelemetry-transport](https://www.npmjs.com/package/pino-opentelemetry-transport) is a transport that will forward logs to an [OpenTelemetry log collector](https://opentelemetry.io/docs/collector/) using [OpenTelemetry JS instrumentation](https://opentelemetry.io/docs/instrumentation/js/). + +```javascript +const pino = require('pino') + +const transport = pino.transport({ + target: 'pino-opentelemetry-transport', + options: { + resourceAttributes: { + 'service.name': 'test-service', + 'service.version': '1.0.0' + } + } +}) + +pino(transport) +``` + +Documentation on running a minimal example is available in the [README](https://github.com/Vunovati/pino-opentelemetry-transport#minimalistic-example). + + +### pino-papertrail +pino-papertrail is a transport that will forward logs to the [papertrail](https://papertrailapp.com) log service through an UDPv4 socket. + +Given an application `foo` that logs via pino, and a papertrail destination that collects logs on port UDP `12345` on address `bar.papertrailapp.com`, you would use `pino-papertrail` +like so: + +``` +node yourapp.js | pino-papertrail --host bar.papertrailapp.com --port 12345 --appname foo +``` + + +for full documentation of command line switches read [README](https://github.com/ovhemert/pino-papertrail#readme) + + +### pino-pg +[pino-pg](https://www.npmjs.com/package/pino-pg) stores logs into PostgreSQL. +Full documentation in the [README](https://github.com/Xstoudi/pino-pg). + ### pino-redis @@ -725,6 +965,27 @@ For full documentation of command line switches see the [pino-sentry README](htt [pino-sentry]: https://www.npmjs.com/package/pino-sentry [Sentry]: https://sentry.io/ + +### pino-sentry-transport + +[pino-sentry-transport][pino-sentry-transport] is a Pino v7+ compatible transport to forward log events to [Sentry][Sentry] +from a dedicated worker: + +```js +const pino = require('pino') +const transport = pino.transport({ + target: 'pino-sentry-transport', + options: { + sentry: { + dsn: 'https://******@sentry.io/12345', + } + } +}) +pino(transport) +``` + +[pino-sentry-transport]: https://github.com/tomer-yechiel/pino-sentry-transport +[Sentry]: https://sentry.io/ ### pino-seq @@ -756,55 +1017,32 @@ pino(transport) [pino-seq-transport]: https://github.com/autotelic/pino-seq-transport [Seq]: https://datalust.co/seq - -### pino-sentry-transport + +### pino-slack-webhook -[pino-sentry-transport][pino-sentry-transport] is a Pino v7+ compatible transport to forward log events to [Sentry][Sentry] +[pino-slack-webhook][pino-slack-webhook] is a Pino v7+ compatible transport to forward log events to [Slack][Slack] from a dedicated worker: ```js const pino = require('pino') const transport = pino.transport({ - target: 'pino-sentry-transport', + target: '@youngkiu/pino-slack-webhook', options: { - sentry: { - dsn: 'https://******@sentry.io/12345', - } + webhookUrl: 'https://hooks.slack.com/services/xxx/xxx/xxx', + channel: '#pino-log', + username: 'webhookbot', + icon_emoji: ':ghost:' } }) pino(transport) ``` -[pino-sentry-transport]: https://github.com/tomer-yechiel/pino-sentry-transport -[Sentry]: https://sentry.io/ - - - -### pino-airbrake-transport - -[pino-airbrake-transport][pino-airbrake-transport] is a Pino v7+ compatible transport to forward log events to [Airbrake][Airbrake] -from a dedicated worker: +[pino-slack-webhook]: https://github.com/youngkiu/pino-slack-webhook +[Slack]: https://slack.com/ -```js -const pino = require('pino') -const transport = pino.transport({ - target: 'pino-airbrake-transport', - options: { - airbrake: { - projectId: 1, - projectKey: "REPLACE_ME", - environment: "production", - // additional options for airbrake - performanceStats: false, - }, - }, - level: "error", // minimum log level that should be sent to airbrake -}) -pino(transport) -``` +[pino-pretty]: https://github.com/pinojs/pino-pretty -[pino-airbrake-transport]: https://github.com/enricodeleo/pino-airbrake-transport -[Airbrake]: https://airbrake.io/ +For full documentation of command line switches read the [README](https://github.com/abeai/pino-websocket#readme). ### pino-socket @@ -828,69 +1066,6 @@ Logs from the application should be observed on both consoles. [pino-socket]: https://www.npmjs.com/package/pino-socket - -### pino-datadog-transport - -[pino-datadog-transport][pino-datadog-transport] is a Pino v7+ compatible transport to forward log events to [Datadog][Datadog] -from a dedicated worker: - -```js -const pino = require('pino') -const transport = pino.transport({ - target: 'pino-datadog-transport', - options: { - ddClientConf: { - authMethods: { - apiKeyAuth: - } - }, - }, - level: "error", // minimum log level that should be sent to datadog -}) -pino(transport) -``` - -[pino-datadog-transport]: https://github.com/theogravity/pino-datadog-transport -[Datadog]: https://www.datadoghq.com/ - -#### Logstash - -The [pino-socket][pino-socket] module can also be used to upload logs to -[Logstash][logstash] via: - -``` -$ node app.js | pino-socket -a 127.0.0.1 -p 5000 -m tcp -``` - -Assuming logstash is running on the same host and configured as -follows: - -``` -input { - tcp { - port => 5000 - } -} - -filter { - json { - source => "message" - } -} - -output { - elasticsearch { - hosts => "127.0.0.1:9200" - } -} -``` - -See to learn -how to setup [Kibana][kibana]. - -For Docker users, see -https://github.com/deviantony/docker-elk to setup an ELK stack. - ### pino-stackdriver The [pino-stackdriver](https://www.npmjs.com/package/pino-stackdriver) module is a transport that will forward logs to the [Google Stackdriver](https://cloud.google.com/logging/) log service through its API. @@ -926,147 +1101,6 @@ Example output for the "hello world" log: [rfc3164]: https://tools.ietf.org/html/rfc3164 [logstash]: https://www.elastic.co/products/logstash - - -### pino-websocket - -[pino-websocket](https://www.npmjs.com/package/@abeai/pino-websocket) is a transport that will forward each log line to a websocket server. - -```sh -$ node app.js | pino-websocket -a my-websocket-server.example.com -p 3004 -``` - -For full documentation of command line switches read the [README](https://github.com/abeai/pino-websocket#readme). - - -### pino-slack-webhook - -[pino-slack-webhook][pino-slack-webhook] is a Pino v7+ compatible transport to forward log events to [Slack][Slack] -from a dedicated worker: - -```js -const pino = require('pino') -const transport = pino.transport({ - target: '@youngkiu/pino-slack-webhook', - options: { - webhookUrl: 'https://hooks.slack.com/services/xxx/xxx/xxx', - channel: '#pino-log', - username: 'webhookbot', - icon_emoji: ':ghost:' - } -}) -pino(transport) -``` - -[pino-slack-webhook]: https://github.com/youngkiu/pino-slack-webhook -[Slack]: https://slack.com/ - -[pino-pretty]: https://github.com/pinojs/pino-pretty - -For full documentation of command line switches read the [README](https://github.com/abeai/pino-websocket#readme). - - -### pino-axiom - -[pino-axiom](https://www.npmjs.com/package/pino-axiom) is a transport that will forward logs to [Axiom](https://axiom.co). - -```javascript -const pino = require('pino') -const transport = pino.transport({ - target: 'pino-axiom', - options: { - orgId: 'YOUR-ORG-ID', - token: 'YOUR-TOKEN', - dataset: 'YOUR-DATASET', - }, -}) -pino(transport) -``` - - -### pino-opentelemetry-transport - -[pino-opentelemetry-transport](https://www.npmjs.com/package/pino-opentelemetry-transport) is a transport that will forward logs to an [OpenTelemetry log collector](https://opentelemetry.io/docs/collector/) using [OpenTelemetry JS instrumentation](https://opentelemetry.io/docs/instrumentation/js/). - -```javascript -const pino = require('pino') - -const transport = pino.transport({ - target: 'pino-opentelemetry-transport', - options: { - resourceAttributes: { - 'service.name': 'test-service', - 'service.version': '1.0.0' - } - } -}) - -pino(transport) -``` - -Documentation on running a minimal example is available in the [README](https://github.com/Vunovati/pino-opentelemetry-transport#minimalistic-example). - - -### @axiomhq/pino - -[@axiomhq/pino](https://www.npmjs.com/package/@axiomhq/pino) is the official [Axiom](https://axiom.co/) transport for Pino, using [axiom-js](https://github.com/axiomhq/axiom-js). - -```javascript -import pino from 'pino'; - -const logger = pino( - { level: 'info' }, - pino.transport({ - target: '@axiomhq/pino', - options: { - dataset: process.env.AXIOM_DATASET, - token: process.env.AXIOM_TOKEN, - }, - }), -); -``` - -then you can use the logger as usual: - -```js -logger.info('Hello from pino!'); -``` - -For further examples, head over to the [examples](https://github.com/axiomhq/axiom-js/tree/main/examples/pino) directory. - - -### pino-discord-webhook - -[pino-discord-webhook](https://github.com/fabulousgk/pino-discord-webhook) is a Pino v7+ compatible transport to forward log events to a [Discord](http://discord.com) webhook from a dedicated worker. - -```js -import pino from 'pino' - -const logger = pino({ - transport: { - target: 'pino-discord-webhook', - options: { - webhookUrl: 'https://discord.com/api/webhooks/xxxx/xxxx', - } - } -}) -``` - - -### pino-logfmt - -[pino-logfmt](https://github.com/botflux/pino-logfmt) is a Pino v7+ transport that formats logs into [logfmt](https://brandur.org/logfmt). This transport can output the formatted logs to stdout or file. - -```js -import pino from 'pino' - -const logger = pino({ - transport: { - target: 'pino-logfmt' - } -}) -``` - ### pino-telegram-webhook @@ -1094,6 +1128,17 @@ logger.error('test log!'); The `extra` parameter is optional. Parameters that the method [`sendMessage`](https://core.telegram.org/bots/api#sendmessage) supports can be passed to it. + +### pino-websocket + +[pino-websocket](https://www.npmjs.com/package/@abeai/pino-websocket) is a transport that will forward each log line to a websocket server. + +```sh +$ node app.js | pino-websocket -a my-websocket-server.example.com -p 3004 +``` + +For full documentation of command line switches read the [README](https://github.com/abeai/pino-websocket#readme). + ### pino-yc-transport @@ -1121,53 +1166,6 @@ logger.error(new Error("error")); logger.fatal("fatal"); ``` - -### @macfja/pino-fingers-crossed - -[@macfja/pino-fingers-crossed](https://github.com/MacFJA/js-pino-fingers-crossed) is a Pino v7+ transport that holds logs until a log level is reached, allowing to only have logs when it matters. - -```js -const pino = require('pino'); -const { default: fingersCrossed, enable } = require('@macfja/pino-fingers-crossed') - -const logger = pino(fingersCrossed()); - -logger.info('Will appear immedialty') -logger.error('Will appear immedialty') - -logger.setBindings({ [enable]: 50 }) -logger.info('Will NOT appear immedialty') -logger.info('Will NOT appear immedialty') -logger.error('Will appear immedialty as well as the 2 previous messages') // error log are level 50 -logger.info('Will NOT appear') -logger.info({ [enable]: false }, 'Will appear immedialty') -logger.info('Will NOT appear') -``` - -### pino-hana -[pino-hana](https://github.com/HiImGiovi/pino-hana) is a Pino v7+ transport that save pino logs to a SAP HANA database. -```js -const pino = require('pino') -const logger = pino({ - transport: { - target: 'pino-hana', - options: { - connectionOptions: { - host: , - port: , - user: , - password: , - }, - schema: , - table:
, - }, - }, -}) - -logger.info('hi') // this log will be saved into SAP HANA -``` -For more detailed information about its usage please check the official [documentation](https://github.com/HiImGiovi/pino-hana#readme). - ## Communication between Pino and Transports Here we discuss some technical details of how Pino communicates with its [worker threads](https://nodejs.org/api/worker_threads.html).