在记录自定义信息时,例如在rake-task中,我想缩进日志行以获得更好的可读性。例如:
Seeding database...
Importing xyz.csv...
Skipping row 5 due to invalid value 'Unknown' in column 'year'
Finished importing xyz.csv
Finished seeding database在我的seeds.rb中,我使用以下方式进行日志记录:
logger = Logger.new(STDOUT)
logger.info('Seeding database...')然而,Skipping row 5...的日志记录发生在一个服务中,这个服务不一定要从seeds.rb调用,而是可以从任何地方调用。因此,我无法硬编码正确的缩进(这听起来是个坏主意)。
一种可能是保留一个“缩进计数器”,当我开始导入一个文件时,它会增加,在完成时会减少。不过,我不确定如何从我的应用程序中的任何地方访问它,或者这是否是最好的解决方案。有什么想法吗?
发布于 2019-09-12 17:00:41
更好的解决方案是为服务对象提供一个记录器对象以及要处理的数据。这样,它就不必知道任何关于记录器首选项的信息。
并使用这样的方法:
require 'logger'
class IndentedLogger < Logger
INDENTATION_STR = ' '.freeze
attr_accessor :indentation
def initialize(io, *args, **params)
self.indentation = 0
super
end
def indented
return self.dup.tap{|l| l.indentation += 1 } unless block_given?
self.indentation += 1
yield self
self.indentation -= 1
end
protected
def format_message(severity, datetime, progname, msg)
(@formatter || @default_formatter).call(severity, datetime, progname, "#{INDENTATION_STR*indentation}#{msg}")
end
end
# Example:
logger = IndentedLogger.new(STDOUT)
logger.info "Foo"
logger.indented{
logger.info "Foo"
logger.indented.info "Indented even more"
}
logger.info "Foo"以及服务呼叫- YourService.new(some_data, logger: logger.indented).process_or_whatever
https://stackoverflow.com/questions/52983137
复制相似问题