微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何重新格式化 Ruby 日志记录 MDC['context']

如何解决如何重新格式化 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.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?