golang zap日志库 打印日志时显示的源文件始终是同一个问题解决方法 zap.Option函数可选项 zap.AddCallerSkip(1) 使用示例
这种情况一般出现在我们对zap日志库进行二次封装的情况下, 在打印日志的时候的源文件非我们期望的文件,如下
原因分析
出现这个问题的原因是zap函数内部在调用 runtime.Caller 时的skip层级不对了,因为我们进行了二次封装,所以zap框架默认的skip就需要进行自定义调整,
解决方法
在使用 zap.New 初始化zap日志库的时候,在第2个可选参数里面增加 zap.AddCallerSkip(1) 即可解决。
注意, 上面的的 zap.AddCallerSkip(1) 这个是一个zap.Option选项函数。 增加后的效果如下
zap.Option可选函数定义参考
// An Option configures a Logger.
type Option interface {apply(*Logger)
}// optionFunc wraps a func so it satisfies the Option interface.
type optionFunc func(*Logger)func (f optionFunc) apply(log *Logger) {f(log)
}// AddCallerSkip increases the number of callers skipped by caller annotation
// (as enabled by the AddCaller option). When building wrappers around the
// Logger and SugaredLogger, supplying this Option prevents zap from always
// reporting the wrapper code as the caller.
func AddCallerSkip(skip int) Option {return optionFunc(func(log *Logger) {log.callerSkip += skip})
}
这个Option apply函数可选项,在很多的知名框架中都被广泛使用,所以学习golang的小伙伴们有必要对这种使用模式进行学习哦。