如何解决如何重新格式化 Ruby 日志记录 MDC['context']
我正在努力使我的日志在不同语言上更加一致。当 Ruby 打印散列时,它使用散列火箭“=>”将键与值分开。当我搜索日志时,我希望能够将这些键/值仅用“=”分隔。这样,“customer=1”,在日志搜索中也会显示我的 java 日志中的内容。我在 Rails 应用程序中使用带有 MDC 的 Ruby 日志记录库,特别需要重新格式化 Logging.mdc['context'],但我不知道将代码放在哪里,而不必更改底层日志记录 gem。我可以在 logging.rb 中使用稳定的 lambda 运算符吗?或者是否有其他方式注入在打印日志行时执行的代码?或者更好的是,是否有一些神奇的格式代码可以存在于 logging.rb (Logging.layouts.pattern) 中?
我正在考虑这样的事情,但我相信它可以重构为更短的内容:
def reformat_context
reformatted_mdc_context = ""
Logging.mdc['context'].each { |k,v| reformatted_mdc_context += "#{k}=#{v} "}
Logging.mdc['context'].clear
Logging.mdc['context'] = reformatted_mdc_context
end
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。