log4j postgres в Java EE - PullRequest
       22

log4j postgres в Java EE

6 голосов
/ 10 мая 2011

После долгих поисков по теме я, наконец, думаю, что решение моей проблемы - спросить вас.

Так что моя проблема в том, чтобы создавать журналы использования моего веб-приложения.

Я нашел библиотеку java log4j, но я не понимаю, как это работает ..

Где мне создать файл конфигурации?

Где и как на него ссылаться?

Могу ли я создать класс, который подключается к postgres и вставляет в журнал мои три параметра?

Вот что я нашел в сети:

. / SRC / log4j / log4j.properties

log4j.rootCategory = FATAL, CONSOLE
# definition de l'appender console
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern = %d [%t] %-5p %c - %m%n

# definition de l'appender JDBC
log4j.appender.JDBC=org.apache.log4j.jdbcplus.JDBCAppender
log4j.appender.JDBC.layout=org.apache.log4j.PatternLayout
# appender pour base postgresql
log4j.appender.JDBC.dbclass=org.postgresql.Driver
# parametres de la base
log4j.appender.JDBC.url=jdbc:postgresql://127.0.0.1:5432/baseSQL
log4j.appender.JDBC.username=user
log4j.appender.JDBC.password=password
# requete sql qui decoupe le message suivant les barres verticales et fait l'insert dans la table
log4j.appender.JDBC.sql=INSERT INTO logs (id, user, info1, info2, timestamp) VALUES (nextval('sequence_logs'), split_part('@MSG@','|',1), split_part('@MSG@','|',2), split_part('@MSG@','|',3), '@TIMESTAMP@')

#declaration des loggers de l'application
log4j.logger.paquetage.de.mon.appli=FATAL, CONSOLE
log4j.logger.loggerDB=INFO,JDBC
# definition de non additivite des loggers
log4j.additivity.loggerDB=false

ЦСИ / log4j / LogsInfos.java

package log4j;

import org.apache.log4j.Logger;

public final class LogsInfos {

    /** Declaration du Logger DB. */
    private static Logger loggerDB = Logger.getLogger("loggerDB");

    /**
     * Enregistre le log.
     * @param param parametres du log
     */
    public static void enregistreLog(String user, String action, String sujet) {
//      Date date=new Date();
        if (loggerDB.isInfoEnabled()) {
            // creation du message final
            final String log = new StringBuffer(user).append(action).append(sujet).toString();
            // envoi du log au logger base
            loggerDB.info(log);
        }
    }
}

звонок в моем пакете

LogsInfos.enregistreLog((String)session.getAttribute("cn"),"Suppression",personne.getCn());

Могу ли я использовать объект по своему выбору?

Этот код является решением? если это так, где я должен вызвать файл конфигурации?

EDIT: Это сообщение об ошибке консоли при выполнении:

log4j:ERROR Could not instantiate class [org.apache.log4j.jdbcplus.JDBCAppender].
java.lang.ClassNotFoundException: org.apache.log4j.jdbcplus.JDBCAppender
...
log4j:ERROR Could not instantiate appender named "JDBC".
log4j:WARN No appenders could be found for logger (loggerDB).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

1 Ответ

3 голосов
/ 10 мая 2011

Вам не хватает jdbcappender.jar в вашем пути к классам. Я думаю, что вы ищете этот . Или вы можете пойти с официальным JDBCAppender , но я не уверен, достаточно ли он силен для ваших нужд.

Где я должен создать файл конфигурации?

Большинство людей создают его в корне приложения , но я уверен, что ваше читается просто отлично.

Где и как на него ссылаться?

Вам действительно не нужно, если файл конфигурации и библиотеки находятся в пути к классам, все, что вам нужно, это экземпляр Logger.

Могу ли я создать класс, который подключается к postgres и вставляет в журнал мои три параметра?

Да. Вы на правильном пути. Просто поместите необходимые банки в classpath и убедитесь, что ваша строка log4j.appender.JDBC.sql работает. Вы будете использовать методы класса Logger, которые позаботятся обо всем за вас.

Приветствия

...