Как настроить свойства log4j, чтобы каждый поток выводил в свой собственный файл журнала?

У меня есть несколько экземпляров класса потоков, работающих в любой момент времени. У меня есть настройка log4j, которую можно использовать для ведения журнала.

Мне нужен способ настроить log4j, чтобы каждый экземпляр моего класса потока выводил свой журнал в другой файл журнала.

Вот что я сделал (в псевдокоде)

public class doSomething extends Thread {

    private Logger d_logger;

    public doSomething(int id){
       d_logger = Logger.getLogger("doSomething"+id);
       String logFileName = "doSomething"+id+".log";

       Properties prop = new Properties;
       prop.setProperty("doSomething"+id,"DEBUG, WORKLOG");
       prop.setProperty("log4j.appender.WORKLOG","org.apache.log4j.FileAppender");
       prop.setProperty("log4j.appender.WORKLOG.File", logFileName);
       prop.setProperty("log4j.appender.WORKLOG.layout","org.apache.log4j.PatternLayout");
       prop.setProperty("log4j.appender.WORKLOG.layout.ConversionPattern","%d %c{1} - %m%n");
       prop.setProperty("log4j.appender.WORKLOG.Threshold","INFO"); 

       PropertyConfigurator.configure(prop);
    }

    public void run(){
       d_logger.info("Starting to doSomething number" + id);
    }

}

Хотя приведенное выше создает файл для каждого потока, который я создаю, он ничего не выводит в эти файлы. Любая помощь очень ценится.


person Rohan Grover    schedule 23.07.2009    source источник


Ответы (2)


Он ничего не выводит в файлы, потому что правильный синтаксис для настройки регистратора:

prop.setProperty("log4j.logger.doSomething"+id,"DEBUG, WORKLOG");
person matt b    schedule 23.07.2009
comment
Не работает с log4j2, класс PropertyConfigurator больше не поддерживается. - person Sanmoy; 10.10.2017

настройте свой файл log4j.properties следующим образом: предположим, что у вас есть 2 потока с именами ThreadCheckEsportazioni и ThreadAllineaCodiciTrasportoBDN

# imposta a debug il livello del logger di root e lo chiama debug e debugFile
log4j.rootLogger=DEBUG

#logger debug
log4j.logger.it.consorziometis.sispc.exportbdn.job.ThreadAllineaCodiciTrasportoBDN=DEBUG, ThreadAllineaCodiciTrasportoBDN
log4j.logger.it.consorziometis.sispc.exportbdn.job.ThreadCheckEsportazioni=DEBUG, ThreadCheckEsportazioni

# Associa i tipi agli appendere
#log4j.appender.debug=org.apache.log4j.ConsoleAppender
log4j.appender.ThreadCheckEsportazioni=org.apache.log4j.RollingFileAppender
log4j.appender.ThreadAllineaCodiciTrasportoBDN=org.apache.log4j.RollingFileAppender

# Associa un PatternLayout al exportBdn.
log4j.appender.ThreadCheckEsportazioni.layout=org.apache.log4j.PatternLayout
log4j.appender.ThreadCheckEsportazioni.layout.ConversionPattern=[%d][%5p][%c]-> %m%n
log4j.appender.ThreadCheckEsportazioni.File=/apps/consorziometis/procedure_automatiche/ExportBDNService/logs/exportBDN.log
log4j.appender.ThreadCheckEsportazioni.MaxFileSize=10MB
log4j.appender.ThreadCheckEsportazioni.MaxBackupIndex=10
log4j.appender.ThreadCheckEsportazioni.append=true

# Associa un PatternLayout al allineaCodiciTrasporto.
log4j.appender.ThreadAllineaCodiciTrasportoBDN.layout=org.apache.log4j.PatternLayout
log4j.appender.ThreadAllineaCodiciTrasportoBDN.layout.ConversionPattern=[%d][%5p][%c]-> %m%n
log4j.appender.ThreadAllineaCodiciTrasportoBDN.File=/apps/consorziometis/procedure_automatiche/ExportBDNService/logs/allineaCodiciTrasporto.log
log4j.appender.ThreadAllineaCodiciTrasportoBDN.MaxFileSize=10MB
log4j.appender.ThreadAllineaCodiciTrasportoBDN.MaxBackupIndex=10
log4j.appender.ThreadAllineaCodiciTrasportoBDN.append=true

в каждом потоке необходимо установить:

private static Logger log = Logger.getLogger(ThreadCheckEsportazioni.class);

для ThreadCheckEsportazioni и

private static Logger log = Logger.getLogger(ThreadAllineaCodiciTrasportoBDN.class);

для темы ThreadAllineaCodiciTrasportoBDN

person Enrico    schedule 14.06.2018
comment
Может быть, вы могли бы написать названия классов на английском языке? - person TheRealChx101; 07.12.2018