如何重新格式化 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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...