ulog

package
v1.0.0-beta2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 10, 2017 License: MIT Imports: 10 Imported by: 0

README

Logging package

package ulog provides access to the logging library zap for the framework. package ulog uses Zap's configuration wrapped with ulog.Configuration to instantiate the logger. With the configuration object, you can perform pre-initialization setup by injecting configuration, custom logger, and log level prior to building the usable zap.Logger.

ulog provides a few benefits:

  • Context aware logging access via ulog.Logger(ctx) for zap.Logger and ulog.Sugar(ctx) for Sugared logger
  • ulog.Trace creates a zap field that extracts tracing information from a context

ulog.Logger vs ulog.Sugar:

ulog.Logger(ctx)- provides zap.Logger, with high performance API's that requires zap.Fields as values. ulog.Sugar(ctx)- provides sugared implementation of logging APIs that accept values as interface{}

Sample usage

package main

import "go.uber.org/fx/ulog"

func main() {
  // Configure logger with configuration preferred by your service
  logConfig := ulog.Configuration{}

  // Build logger from logConfig object
  log, err := logConfig.Build()

  // Use logger in your service
  log.Info("Message describing logging reason", zap.String("key", "value"))
}

Context

It is very common that in addition to logging a string message, it is desirable to provide additional information: customer uuid, tracing id, etc.

For that very reason, the logging methods (Info,Warn, Debug, etc) take additional parameters as key value pairs.

Retaining Context

Sometimes the same context is used over and over in a logger. For example service name, shard id, module name, etc. For this very reason With() functionality exists which will return a new instance of the logger with that information baked in so it doesn't have to be provided for each logging call.

For example, the following piece of code:

package main

import (
  "context"

  "go.uber.org/fx/ulog"
)

func handleRequest(ctx context.Context) {
  log := ulog.Sugar(ctx)
  log.Infow("My info message")
  log.Infow("Info with context", "customer_id", 1234)

  richLog := log.With("shard_id", 3, "levitation", true)
  richLog.Infow("Rich info message")
  richLog.Infow("Even richer", "more_info", []int{1, 2, 3})
}

Produces this output:

{"level":"info","ts":1479946972.102394,"msg":"My info message"}
{"level":"info","ts":1479946972.1024208,"msg":"Info with context","customer_id":1234}
{"level":"info","ts":1479946972.1024246,"msg":"Rich info message","shard_id":3,"levitation":true}
{"level":"info","ts":1479946972.1024623,"msg":"Even richer","shard_id":3,"levitation":true,"more_info":[1,2,3]}

Configuration

ulog configuration can be defined in multiple ways:

Writing the struct yourself
loggingConfig := ulog.Configuration{
  Stdout: true,
}
Configuration defined in YAML
logging:
  stdout: true
  level: debug

Sentry

ulog has a seamless integration with Sentry. For out-of-the-box usage just include this in your configuration yaml:

logging:
  sentry:
    dsn: http://user:secret@your.sentry.dsn/project

Documentation

Overview

Package ulog is the Logging package.

package ulog provides access to the logging library zap (https://github.com/uber-go/zap)for the framework. package ulog uses Zap's configuration wrapped with ulog.Configuration to instantiate the logger. With the configuration object, you can perform pre-initialization setup by injecting configuration, custom logger, and log level prior to building the usable zap.Logger.

ulog provides a few benefits:

• Context aware logging access via ulog.Logger(ctx) for zap.Logger and ulog.Sugar(ctx) for Sugared logger

• ulog.Trace creates a zap field that extracts tracing information from a context

ulog.Logger vs ulog.Sugar:

ulog.Logger(ctx)- provides zap.Logger, with high performance API's that requires zap.Fields as values. ulog.Sugar(ctx)- provides sugared implementation of logging APIs that accept values as interface{}

Sample usage

package main

import "go.uber.org/fx/ulog"

func main() {
  // Configure logger with configuration preferred by your service
  logConfig := ulog.Configuration{}

  // Build logger from logConfig object
  log, err := logConfig.Build()

  // Use logger in your service
  log.Info("Message describing logging reason", zap.String("key", "value"))
}

Context

It is very common that in addition to logging a string message, it is desirable to provide additional information: customer uuid, tracing id, etc.

For that very reason, the logging methods (Info,Warn, Debug, etc) take additional parameters as key value pairs.

Retaining Context

Sometimes the same context is used over and over in a logger. For example service name, shard id, module name, etc. For this very reason With()functionality exists which will return a new instance of the logger with that information baked in so it doesn't have to be provided for each logging call.

For example, the following piece of code:

package main

import (
  "context"

  "go.uber.org/fx/ulog"
)

func handleRequest(ctx context.Context) {
  log := ulog.Sugar(ctx)
  log.Infow("My info message")
  log.Infow("Info with context", "customer_id", 1234)

  richLog := log.With("shard_id", 3, "levitation", true)
  richLog.Infow("Rich info message")
  richLog.Infow("Even richer", "more_info", []int{1, 2, 3})
}

Produces this output:

{"level":"info","ts":1479946972.102394,"msg":"My info message"}
{"level":"info","ts":1479946972.1024208,"msg":"Info with context","customer_id":1234}
{"level":"info","ts":1479946972.1024246,"msg":"Rich info message","shard_id":3,"levitation":true}
{"level":"info","ts":1479946972.1024623,"msg":"Even richer","shard_id":3,"levitation":true,"more_info":[1,2,3]}

Configuration

ulog configuration can be defined in multiple ways:

Writing the struct yourself

loggingConfig := ulog.Configuration{
  Stdout: true,
}

Configuration defined in YAML

logging:
  stdout: true
  level: debug

Sentry

ulog has a seamless integration with Sentry. For out-of-the-box usage just include this in your configuration yaml:

logging:
  sentry:
    dsn: http://user:secret@your.sentry.dsn/project

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Logger

func Logger(ctx context.Context) *zap.Logger

Logger returns a *zap.Logger that's pre-seeded with tracing information from the provided context.

func Metrics

func Metrics(s tally.Scope) func(zapcore.Entry) error

Metrics returns a function that counts the number of logs emitted by level.

To register it with a zap.Logger, use zap.Hooks.

func SetLogger

func SetLogger(log *zap.Logger) func()

SetLogger uses the provided logger to replace zap's global loggers and hijack output from the standard library's "log" package. It returns a function to undo these changes.

func Sugar

func Sugar(ctx context.Context) *zap.SugaredLogger

Sugar retrieves a loosely-typed zap.SugaredLogger from the provided context.

func Trace

func Trace(ctx context.Context) zapcore.Field

Trace creates a field that extracts tracing information from a context (including trace, span, and parent IDs) and includes it under the "trace" key.

Because the opentracing APIs don't expose this information, the returned zap.Field is a no-op for contexts that don't contain a span or contain a non-Jaeger span.

Types

type Configuration

type Configuration struct {
	zap.Config

	Sentry *sentry.Configuration `yaml:"sentry"`
}

Configuration defines the desired logging options.

func DefaultConfiguration

func DefaultConfiguration() Configuration

DefaultConfiguration returns a fallback configuration for applications that don't explicitly configure logging.

func (Configuration) Build

func (c Configuration) Build(opts ...zap.Option) (*zap.Logger, error)

Build constructs a *zap.Logger with the configured parameters.

func (*Configuration) Configure

func (c *Configuration) Configure(cfg config.Value) error

Configure initializes logging configuration struct from config provider

Directories

Path Synopsis
Package sentry integrates the exception-tracking service Sentry with application logging.
Package sentry integrates the exception-tracking service Sentry with application logging.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL