Предпочтительный способ ведения журнала в работе SpringFrame - PullRequest
2 голосов
/ 23 сентября 2008

Я провел несколько поисков в поисках информации о том, как вести журналы с помощью Spring Framework.

В настоящее время у нас есть приложение, в котором нет входа, за исключением операторов system.out (очень плохой способ).

Что я хотел бы сделать, так это добавить ведение журнала, но также хочу иметь возможность контролировать ведение журнала во время выполнения, скажем, JMX.

Мы используем Rad 7.0 / WebSphere 6.1

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

Обновление: Мысли о следующем Spring AOP Logging Хороший идеал или нет. Это относится к вопросу, опубликованному здесь при ведении журнала: Условное ведение журнала . Это улучшает вещи или просто усложняет ведение журнала?

Ответы [ 3 ]

5 голосов
/ 23 сентября 2008

Я бы использовал Commons Logging и Log4j . Это не совсем вопрос для Spring, однако источник Springframework также использует Commons Logging. Если вы создаете log4j logger и appender в log4j, вы также можете включить ведение журнала в классах Springframework. Есть несколько способов управления журналированием во время выполнения. В изолированной программной среде Log4j есть JSP, который вы можете вставить в свое веб-приложение, что позволит вам контролировать уровни журналов всех регистраторов в вашем приложении.

2 голосов
/ 23 сентября 2008

Смотрите другие ответы для log4j. Но также рассмотрим JAMon для мониторинга приложений . Это очень легко добавить к весеннему приложению, например:

    <bean id="performanceMonitor" class="org.springframework.aop.interceptor.JamonPerformanceMonitorInterceptor">
        <property name="useDynamicLogger" value="false"/>
        <property name="trackAllInvocations" value="true"/>
    </bean>

   <bean id="txRequired" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true">
            <property name="transactionManager" ref="transactionManager"/>
            <property name="transactionAttributes" >
                <props> <prop key="*">PROPAGATION_REQUIRED</prop> </props>
            </property>
        <property name="preInterceptors">
           <list>
              <ref bean="performanceMonitor"/>      
           </list>
        </property>
   </bean>
1 голос
/ 23 сентября 2008

вот пример файла для настройки log4j для консоли и файлового регистратора. если этот файл находится в пути к классам, он будет автоматически прочитан log4j. Однако, поскольку вы находитесь на сервере приложений, может быть другой предпочтительный способ настройки ведения журнала. Я помню, внутри JBoss был XML-файл, который вы должны были изменить. Не уверен насчет конфигурации веб-сферы. Но если вы хотите настроить его для простого тестового приложения, это поможет вам.

# Set root logger level to WARN and appenders to A1 & F1.
log4j.rootLogger=WARN, A1, F1

# A1 is set to be a ConsoleAppender.
log4j.appender.A1=org.apache.log4j.ConsoleAppender
# logging to console only INFO
log4j.appender.A1.Threshold=INFO
# F1 is a file appender
log4j.appender.F1=org.apache.log4j.RollingFileAppender

# Tell Spring to be quiet
log4j.logger.org.springframework=WARN
# debug logging for my classes
log4j.logger.com.yourcorp=DEBUG
log4j.logger.org.hibernate=INFO

# A1 uses PatternLayout.
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%-4r : %d{HH:mm:ss,SSS} [%t] %-5p %c{1} %x - %m%n

log4j.appender.F1.File=./log/mylogfile.log
log4j.appender.F1.MaxFileSize=10MB
log4j.appender.F1.MaxBackupIndex=5
log4j.appender.F1.layout=org.apache.log4j.PatternLayout
log4j.appender.F1.layout.ConversionPattern=%-4r : %d{HH:mm:ss,SSS} [%t] %-5p %c{1} %x - %m%n
...