повторная регистрация в журнале 4j в Java - PullRequest
0 голосов
/ 07 марта 2009

Я использовал log4j в Java-программе. Я инициализировал это с:

BasicConfigurator.configure(); // logger configuration
try {
     logger.setLevel(Level.DEBUG);
} catch (Exception e) {
     System.out.println("Logfile not found");
}

Но во время выполнения программы я получаю 3 оператора журнала вместо одного. Например,

3 lines 
1047 [main] INFO ibis.Preproc.Ratings  - Added AS TIMEZONE to tZones[0] = GMT-12:00
1047 [main] INFO ibis.Preproc.Ratings  - Added AS TIMEZONE to tZones[0] = GMT-12:00
1047 [main] INFO ibis.Preproc.Ratings  - Added AS TIMEZONE to tZones[0] = GMT-12:00

вместо одной строки

1047 [main] INFO ibis.Preproc.Ratings  - Added AS TIMEZONE to tZones[0] = GMT-12:00

Есть ли какие-либо дополнительные настройки, которые необходимо выполнить для log4j, чтобы избежать этого?

Ответы [ 4 ]

4 голосов
/ 07 марта 2009

Я столкнулся с подобным поведением, и оказалось, что Log4J был настроен более одного раза; используя BasicConfigurator, но также и файл log4j.xml, о котором я забыл. Может быть, где-то на пути к классам есть дополнительная конфигурация Log4J?

4 голосов
/ 07 марта 2009

Скорее всего, у вас есть несколько Аппендеров. См. Log4j руководство (Раздел: Дополнения и макеты):

Каждый включенный запрос на запись в журнал для данного регистратора будет перенаправляться всем добавителям в этом регистраторе, а также выше, в иерархии.

Вы можете попробовать установить флаг аддитивности в false.

2 голосов
/ 07 марта 2009

Ну, вы еще не показали, как работает ваша программа. Вот полная программа, которая показывает только одну строку:

import org.apache.log4j.*;

public class Test
{
    public static void main(String[] args)
    {
        BasicConfigurator.configure(); // logger configuration
        Logger logger = Logger.getLogger(Test.class);
        logger.setLevel(Level.DEBUG);
        logger.info("Hello");
    }
}

Возможно ли, что ваш код действительно выполняется три раза?

0 голосов
/ 18 июля 2012

В моем случае я добавлял новый appender каждый раз, когда вызывал BasicConfigurator.configure ().

Я решил, сбросив конфигурацию:

BasicConfigurator.resetConfiguration() //reset first
BasicConfigurator.configure() // then configure

Я должен признаться, что я не совсем понимаю, что происходит, но это, безусловно, решило мою проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...