Skip to content

Latest commit

 

History

History
57 lines (43 loc) · 2.45 KB

README.md

File metadata and controls

57 lines (43 loc) · 2.45 KB

log

log is an out-of-the-box logger, it wraps zap and makes it simpler to use.

Install

$ go get github.com/juan-chan/log@latest

Example

import "github.com/juan-chan/log"

log.Info("Hello, World!")
log.Warn("Hello, Warning!")
log.Error("nil pointer dereference", ErrorField(errors.New("NPE")))
log.Error("some error", ErrorStr(errors.New("what's wrong")))
log.Infof("Today is %s, so happy!", "Friday")
log.Debug("This log should not be displayed")
log.SetDebug()
log.Debug("This log should be displayed")
log.SetLevel(ErrorLevel)
log.Info("This log should not be displayed")
log.Warn("This log should not be displayed")

logger, _ := New(&Config{Encoding: "console"})
log.ReplaceLogger(logger)
log.SetLevel(InfoLevel)
log.Infof("What's your name? My name is %s", "Chan")
log.Error("illegal argument error", String("arg", "name"))

Output:

{"level":"info","time":"2022-11-16 14:09:47.848","caller":"log/logger_test.go:9","msg":"Hello, World!"}
{"level":"warn","time":"2022-11-16 14:09:47.848","caller":"log/logger_test.go:10","msg":"Hello, Warning!"}
{"level":"error","time":"2022-11-16 14:09:47.848","caller":"log/logger_test.go:11","msg":"nil pointer dereference","error":"NPE","stacktrace":"github.com/juan-chan/log.TestLogger\n\t/Users/chenxinyu/Workspace/go/coding/log-github/log/logger_test.go:11\ntesting.tRunner\n\t/usr/local/go/src/testing/testing.go:1446"}
{"level":"error","time":"2022-11-16 14:09:47.848","caller":"log/logger_test.go:12","msg":"some error","error":"what's wrong","stacktrace":"github.com/juan-chan/log.TestLogger\n\t/Users/chenxinyu/Workspace/go/coding/log-github/log/logger_test.go:12\ntesting.tRunner\n\t/usr/local/go/src/testing/testing.go:1446"}
{"level":"info","time":"2022-11-16 14:09:47.848","caller":"log/logger_test.go:13","msg":"Today is Friday, so happy!"}
{"level":"debug","time":"2022-11-16 14:09:47.848","caller":"log/logger_test.go:16","msg":"This log should be displayed"}
2022-11-16 14:09:47.848 INFO    log/logger_test.go:24   What's your name? My name is Chan
2022-11-16 14:09:47.848 ERROR   log/logger_test.go:25   illegal argument error  {"arg": "name"}
github.com/juan-chan/log.TestLogger
        /Users/chan/Workspace/go/log/logger_test.go:25
testing.tRunner
        /usr/local/go/src/testing/testing.go:1446

Sentry

log supports sentry by default, you just need to set an environment variable named: SENTRY_DSN and log will add a hook for it.