首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过yaml在log4r中创建自定义关卡

如何通过yaml在log4r中创建自定义关卡
EN

Stack Overflow用户
提问于 2014-12-10 00:36:51
回答 1查看 198关注 0票数 0

我有一个使用yaml配置的log4r 1.1.10的Rails 4.1应用程序,一切正常。现在我只想添加一个自定义关卡。因此,在我的yaml文件的顶部,我在log4r_config后面添加了7行

代码语言:javascript
复制
log4r_config:
  pre_config:
    custom_levels:
      - INFO
      - WARN
      - ERROR
      - SERIOUS
      - FATAL
  # define all loggers ...
  loggers:

我的application.rb的相关部分如下所示:

代码语言:javascript
复制
require 'log4r'
require 'log4r/yamlconfigurator'
require File.join(File.dirname(__FILE__),"../lib/rollable_file_outputter.rb")
include Log4r
log4r_config = YAML.load_file(File.join(File.dirname(__FILE__),"log4r.yml"))
YamlConfigurator.decode_yaml( log4r_config['log4r_config'] )

但当我现在启动应用程序时,我会得到

代码语言:javascript
复制
ArgumentError: Log level must be in 0..7
/opt/thermyos.com/server/shared/bundle/ruby/2.0.0/gems/log4r-1.1.10/lib/log4r/yamlconfigurator.rb:189:in `decode_logger_common'
/opt/thermyos.com/server/shared/bundle/ruby/2.0.0/gems/log4r-1.1.10/lib/log4r/yamlconfigurator.rb:175:in `decode_logger'
/opt/thermyos.com/server/shared/bundle/ruby/2.0.0/gems/log4r-1.1.10/lib/log4r/yamlconfigurator.rb:69:in `block in decode_yaml'
/opt/thermyos.com/server/shared/bundle/ruby/2.0.0/gems/log4r-1.1.10/lib/log4r/yamlconfigurator.rb:69:in `each'
/opt/thermyos.com/server/shared/bundle/ruby/2.0.0/gems/log4r-1.1.10/lib/log4r/yamlconfigurator.rb:69:in `decode_yaml'
/opt/thermyos.com/server/releases/20141209152838/config/application.rb:23:in `<top (required)>'

在yaml中定义自定义log4r级别的正确方式是什么?

EN

回答 1

Stack Overflow用户

发布于 2014-12-17 23:09:52

解决方案是永远不要遗漏调试级别。这只是我的疏忽。由于Log4r使用调试级别来编写调试消息,因此将其省略是非常糟糕的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27384078

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档