Skip to content

Latest commit

 

History

History
70 lines (56 loc) · 1.42 KB

README.md

File metadata and controls

70 lines (56 loc) · 1.42 KB

logging

  • wrap for zap
  • init from viper
  • log level of each module is set independently

usage

require (
	github.com/izern/logging latest
)

replace github.com/izern/logging latest => github.com/izern/logging-go latest

Quick Start

first, init viper, example yaml

logging:
  #  DEBUG
  #  INFO
  #  WARN
  #  ERROR
  #  PANIC
  #  FATAL
  level:
    root: INFO    # default INFO
    module1.child1: DEBUG
    module1.child2: INFO
    module2: ERROR
  encoding: json # json or console, default json. only encoding, console is plan text encoding
  encoder:
    TimeKey: time
    LevelKey: level
    NameKey: logger
    CallerKey: caller
    MessageKey: msg
    StacktraceKey: stacktrace
  output: # default is console
    console: # console or file. console is output on TTY
      async: false # async output,default false
    file:
      path: /tmp/golang/log.log
      async: false # async output,default false

and init viper

  gopath, b := os.LookupEnv("GOPATH")
  assert.Truef(t, b, "no GOPATH ENV")
  viper.SetConfigFile(gopath + "/src/github.com/izern/logging-go/config.yaml")
  err := viper.ReadInConfig()

then init logging, and get logger

  InitZapLoggerFromViper(viper.GetViper())
  log := GetLogger("module1.child1")
  log = GetLogger("module1.child1.child")
  log = GetLogger("test")

enjoy~ beginning your APP