问题描述
我正在努力使我的日志在不同语言上更加一致。当 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 (将#修改为@)