在运行时设置log4j日志文件

js4nwp54  于 2021-07-09  发布在  Java
关注(0)|答案(1)|浏览(439)

我正在开发一个使用slf4j的java程序。目前,该程序包含以下行:

class MyOwn{
    Logger logger; //org.slf4j.*;
    static {
    PropertyConfigurator.configure("somePathTo/log4j.properties");//log4j
    logger = LoggerFactory.getLogger(MyOwn.class);
}

     ... // rest of my code is here
 }

我的问题是:为了在运行时指定日志文件的名称,我需要做哪些修改。
背景:基本上,当程序运行时,它应该 x 按顺序的作业数。对于每个作业,我需要不同的文件名。
log4j.properties文件不是xml;它是文本,我必须保持这种方式。我找到了这个链接(http://cognitivecache.blogspot.com/2008/08/log4j-writing-to-dynamic-log-file-for.html)但我不知道如何使用那里的信息。
编辑
下面是我当前的log4j.properties文件。我希望能够在log4j.properties文件(即。 /opt/stuff/var/log/jmy/proj/ )换个地方就行了 myown.log 使用动态文件名。我该怎么做?同样,我想保留log4j属性。

log4j.appender.CONSOLE=org.apache.     log4j.ConsoleAppender
 log4j.appender.CONSOLE.layout=org.apache.     log4j.PatternLayout
 log4j.appender.CONSOLE.layout.ConversionPattern=%d %-5p %c{1} - %m%n

 log4j.rootLogger=INFO, CONSOLE

 log4j.appender.MY_OWN_ERR_LOG=org.apache.     log4j.RollingFileAppender
 log4j.appender.MY_OWN_ERR_LOG.File=/opt/stuff/var/log/jmy/proj/myown.error.log
 log4j.appender.MY_OWN_ERR_LOG.MaxFileSize=4MB
 log4j.appender.MY_OWN_ERR_LOG.MaxBackupIndex=3
 log4j.appender.MY_OWN_ERR_LOG.layout=org.apache.     log4j.PatternLayout
 log4j.appender.MY_OWN_ERR_LOG.layout.ConversionPattern=%d %-5p %c{1} - %m%n
 log4j.appender.MY_OWN_ERR_LOG.Threshold = WARN

 log4j.appender.MY_OWN_LOG=org.apache.     log4j.RollingFileAppender
 log4j.appender.MY_OWN_LOG.File=/opt/stuff/var/log/jmy/proj/myown.log
 log4j.appender.MY_OWN_LOG.MaxFileSize=8MB
 log4j.appender.MY_OWN_LOG.MaxBackupIndex=3
 log4j.appender.MY_OWN_LOG.layout=org.apache.     log4j.PatternLayout
 log4j.appender.MY_OWN_LOG.layout.ConversionPattern=%d %-5p %c{1} - %m%n

 log4j.logger.my.own.things=DEBUG, MY_OWN_LOG, MY_OWN_ERR_LOG
tvokkenx

tvokkenx1#

请看这篇文章,它使用log4j以编程方式创建不同的日志文件
您可以指定任何可以通过编程方式放入log4j.properties文件的内容。您只需创建appender和logger对象并将它们链接在一起。
另请参见此处以获取更完整的示例:http://configlog4jbyprogram.blogspot.co.uk/

相关问题