@bedrockio/instrumentation v1.4.18
@bedrockio/instrumentation
This providers tools to instrumentate your api
- Expose logger (wrapping https://getpino.io)
- Http logging middleware
- Providers tracing of your application via https://opentelemetry.io/
For exporting both logging and tracing: The package assumes you are running in a Google Cloud environment (production). Locally its using https://zipkin.io/. If a server is available.
Install
npm install @bedrockio/instrumentationUsage
Important This should be initalized before any other code is executed / required or it will not work correctly.
const { setupTelemetry } = require("@bedrockio/instrumentation");
if (process.env.NODE_ENV === "production") {
  setupTelemetry();
}
// other codeDevelopment vs Production
When process.env.NODE_ENV != production some features are turned off or swapped out with development friendly solutions:
- Tracing/Instrumention is turned off (makes boot time faster)
- Simple output rendering using console
- Allows silencing output with log levels.
Log Levels
Setting process.env.LOG_LEVEL will set the log level which silences lower level output. The levels are:
- trace
- debug
- info
- warn
- error
- fatal
Methods
setupTelemetry
setup the instrumentations (tracing).
getTracer
Returns a tracer from the global tracer provider
createLogger
createLogger(props): LoggerloggingMiddleware
Http logging middleware
Properties
logger
logger.info("Hello", { "foo": "bar" })The default logger
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago