Go 中禁用语句的高效日志记录
在关键路径中,嵌入可在以下位置动态切换的调试/跟踪日志记录语句是有益的运行时。这种做法非常适合调试离线生产系统或测试镜像生产环境的系统。
但是,这种类型的日志记录有一个关键要求:禁用的语句必须对性能影响最小。在 C/C 中,这是通过 LOG 宏实现的,该宏抑制参数求值,直到检查标志为止。
在 Go 中实现禁用日志记录
在 Go 中模拟此行为提出了挑战。将 io.Discard 与 log.Logger 一起使用不是一个选项,因为即使在禁用时它也会格式化日志消息。
使用 EnabledLogger 结构的初始尝试实现了 log.Logger 接口,根据 Enabled 启用/禁用日志记录旗帜。但是,参数求值仍然不受抑制,可能会导致任意函数调用的性能问题。
两种解决方法
要解决此问题,有两种解决方法:
这两种方法都会导致冗长且容易出错的代码,从而为潜在的性能下降打开了大门。
其他选项
尽管 Go 有静态评估规则,但还有一些附加选项:
虽然这些解决方案对于动态运行时配置并不理想,他们可以在特定场景中引入性能改进。
以上是Go中如何实现禁用语句的高效日志记录?的详细内容。更多信息请关注PHP中文网其他相关文章!