我有两个类(class)A和B。我想使用根目录中的单个 log4j.properties 将 A 类记录到 a.log,将 B 类记录到 b.log,到目前为止我的努力:
在A类中:
private static final Logger l = Logger.getLogger("classa");
B类:
private static final Logger l = Logger.getLogger("classb");
log4j.属性:
log4j.logger.classa=ALL,A1
log4j.appender.A1=org.apache.log4j.RollingFileAppender
log4j.appender.A1.append=false
log4j.appender.A1.MaxBackupIndex=1
log4j.appender.A1.file=a.log
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
log4j.logger.classb=ALL,A2
log4j.appender.A2=org.apache.log4j.RollingFileAppender
log4j.appender.A2.append=false
log4j.appender.A2.MaxBackupIndex=1
log4j.appender.A2.file=b.log
log4j.appender.A2.layout=org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
有什么想法吗?
最佳答案
这有效!
通过类名检索:
private static final Logger l = Logger.getLogger(MyClass.class.getName());
两个类名记录器:
log4j.logger.my.package.MyClassA=Debug,A1
log4j.logger.my.package.MyClassB=Debug,A2
关于java - Log4j 具有不同记录器和一个属性文件的多个类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16733242/