有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

JRuby on Rails应用程序中的java log4j将日志重定向到单独的文件

我想在我的JRuby on Rails应用程序中获得更细粒度的日志记录。我介绍了log4j。我当前有一个如下所示的属性文件:

log4j.rootLogger=INFO, stdout

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

#
log4j.logger.Rails=INFO, A

log4j.appender.A=org.apache.log4j.RollingFileAppender
log4j.appender.A.File=/usr/share/tomcat6/logs/production.log
log4j.appender.A.MaxFileSize=10000KB
log4j.appender.A.MaxBackupIndex=5
log4j.appender.A.layout=org.apache.log4j.PatternLayout
log4j.appender.A.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

去拿铁轨。若要使用此功能,我将弹出以下初始值设定项:

org.apache.log4j.PropertyConfigurator.configure("#{::Rails.root.to_s}/config/log4j.properties")

现在,我还想做一些事情,比如:

Rails.logger.feature_1("Log to feature_1.log")
Rails.logger.feature_N("Log to feature_N.log")

实现这一点的最佳方法是什么,这样就不会将所有内容都放在一个日志文件中

还需要注意的是,我正在使用博客中提到的适配器:http://squaremasher.blogspot.com/2009/08/jruby-rails-and-log4j.html


共 (1) 个答案

  1. # 1 楼答案

    首先,您应该为log4j.properties文件中需要的每个“功能”定义一个appender/logger配置:

    ...
    log4j.logger.Rails=INFO, A
    
    log4j.appender.A=org.apache.log4j.RollingFileAppender
    log4j.appender.A.File=/usr/share/tomcat6/logs/production.log
    
    ...
    log4j.logger.feature_1=INFO, feature_1
    
    log4j.appender.feature_1=org.apache.log4j.RollingFileAppender
    log4j.appender.feature_1.File=/path/to/your/feature_1.log
    ...
    log4j.logger.feature_N=INFO, feature_N
    
    log4j.appender.feature_N=org.apache.log4j.RollingFileAppender
    log4j.appender.feature_N.File=/path/to/your/feature_N.log
    

    这样,每个记录器都有自己的严重性过滤器和目标文件

    然后,您可以根据在月球的Ruby一侧调用的方法(来自您提供的示例适配器)来选择它,而不是总是使用同一个记录器:

    class Log4jAdapter
    
      def method_missing(meth, *args)
        # Checking the method name matches feature_N
        if /\Afeature_(\d+)\z/ =~ method.to_s
          # Retrieve the appropriate logger => getLogger('feature_N')
          logger = org.apache.log4j.Logger.getLogger(method.to_s)
          # Log !
          logger.log *args
        else
            puts "UNSUPPORTED METHOD CALLED: #{meth}"
        end
      end
    
    end
    

    未经测试,但我想你会明白的