在大型项目中,使用logrus
进行日志打印,如不加一些如[usecase.CreateUser]
前缀,将会很难定位到打印日志的代码位置。故liamylian/logrus-ext借鉴了python的logging模块,对logrus
进行了简单封装。从而能够在日志中打印当前的模块名和调用函数名。python
var log = Get("usecase", &Option{WithFunc: true}) // 输出: // time="2019-04-18T15:36:37+08:00" level=error msg="query task error: id=1" error="too many connection" // func="github.com/liamylian/logrus-ext.(*db).QueryTask" name=usecase err := errors.New("too many connection") log.WithError(err).Errorf("query task error: id=%d", id)