2011-03-14 5 views
31

패키지 이름에 따라 다른 파일에 log4j를 기록하도록 설정하려면 어떻게해야합니까? 예를 들어log4j : 패키지 별 로깅

: 나는 속성을 사용하고

com.myname.fred logs to fred.log 
com.myname.derek logs to derek.log 

은 설정 형식을 파일. 현재 서버용으로 설정되었으므로 혼자 남겨두고 내 로깅을 위해 물건을 추가하고 싶습니다. 당신은 이에 따라 두 개의 새로운 펜더 및 설정 가산을 만들 필요가

## 
## Licensed to the Apache Software Foundation (ASF) under one or more 
## contributor license agreements. See the NOTICE file distributed with 
## this work for additional information regarding copyright ownership. 
## The ASF licenses this file to You under the Apache License, Version 2.0 
## (the "License"); you may not use this file except in compliance with 
## the License. You may obtain a copy of the License at 
## 
## http://www.apache.org/licenses/LICENSE-2.0 
## 
## Unless required by applicable law or agreed to in writing, software 
## distributed under the License is distributed on an "AS IS" BASIS, 
## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
## See the License for the specific language governing permissions and 
## limitations under the License. 
## 
## $Rev: 564818 $ $Date: 2007-08-10 22:28:29 -0400 (Fri, 10 Aug 2007) $ 
## 

log4j.rootLogger=INFO, CONSOLE, FILE 

log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender 
log4j.appender.CONSOLE.Threshold=${org.apache.geronimo.log.ConsoleLogLevel} 
log4j.appender.CONSOLE.Target=System.out 
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout 
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ABSOLUTE} %-5p [%c{1}] %m%n 

log4j.appender.FILE=org.apache.log4j.RollingFileAppender 
log4j.appender.FILE.Threshold=TRACE 
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout 
log4j.appender.FILE.layout.ConversionPattern=%d{ABSOLUTE} %-5p [%c{1}] %m%n 

# 
# Note, changing log4j.appender.FILE.append=false will result in logs being 
# overwritten without archiving the previous version of the log. 
# 
log4j.appender.FILE.append=true 
log4j.appender.FILE.file=${org.apache.geronimo.server.dir}/var/log/geronimo.log 
log4j.appender.FILE.bufferedIO=false 
log4j.appender.FILE.maxBackupIndex=3 
log4j.appender.FILE.maxFileSize=10MB 

# 
# Example: enable trace logging from CONSOLE appender 
# 
#log4j.appender.CONSOLE.Threshold=TRACE#org.apache.geronimo.system.logging.log4j.XLevel 

# 
# Example: enable trace messages from foo.bar category 
# 
#log4j.logger.foo.bar=TRACE#org.apache.geronimo.system.logging.log4j.XLevel 

# Geronimo 
#This will help find connection leak problems 
#log4j.logger.org.apache.geronimo.connector.outbound=TRACE#org.apache.geronimo.system.logging.log4j.XLevel 
log4j.logger.org.apache.geronimo.system.logging.log4j.Log4jService=INFO 

#### Eliminate any INFO level output during normal operation -- except the really relevant stuff #### 
# We can change the Geronimo code to avoid this, but we have to just adjust the log levels for 
# any third-party libraries. 
log4j.logger.org.apache.commons.digester=ERROR 
log4j.logger.org.apache.jasper.compiler.SmapUtil=WARN 

# ActiveMQ 
log4j.logger.org.apache.activemq=WARN 
log4j.logger.org.apache.activemq.broker.jmx.ManagementContext=ERROR 

# Don't need so much info on every web page that's rendered 
log4j.logger.org.mortbay=INFO 
log4j.logger.org.apache.pluto=INFO 
log4j.logger.org.apache.jasper=INFO 

# Various Jetty startup/shutdown output 
log4j.logger.org.mortbay.http.HttpServer=WARN 
log4j.logger.org.mortbay.http.SocketListener=WARN 
log4j.logger.org.mortbay.http.ajp.AJP13Listener=WARN 
log4j.logger.org.mortbay.util.Container=WARN 
log4j.logger.org.mortbay.util.Credential=WARN 
log4j.logger.org.mortbay.util.ThreadedServer=WARN 
log4j.logger.org.mortbay.jetty.servlet.WebApplicationContext=WARN 
log4j.logger.org.mortbay.jetty.context=WARN 

# Various Tomcat startup output 
log4j.logger.org.apache.catalina.realm.JAASRealm=WARN 
log4j.logger.org.apache.catalina.realm.RealmBase=WARN 
log4j.logger.org.apache.catalina.loader.WebappLoader=WARN 
log4j.logger.org.apache.catalina.startup.Embedded=WARN 
log4j.logger.org.apache.catalina.core.StandardEngine=WARN 
log4j.logger.org.apache.catalina.core.StandardHost=WARN 
log4j.logger.org.apache.jk.common.ChannelSocket=WARN 
log4j.logger.org.apache.jk.server.JkMain=WARN 
log4j.logger.org.apache.coyote.http11.Http11BaseProtocol=WARN 
log4j.logger.org.apache.coyote.http11.Http11Protocol=WARN 
log4j.logger.org.apache.catalina.core.ContainerBase=WARN 
log4j.logger.org.apache.catalina.core.StandardContext=WARN 
log4j.logger.org.apache.tomcat.util.net.SSLImplementation=WARN 

# myfaces startup output 
log4j.logger.org.apache.myfaces.renderkit.html.HtmlRenderKitImpl=WARN 
log4j.logger.org.apache.myfaces.config.FacesConfigurator=WARN 
log4j.logger.org.apache.myfaces.webapp.StartupServletContextListener=WARN 
log4j.logger.org.apache.myfaces.webapp.StartupServletContextListener=WARN 

# emits a spurious warn about null locale during startup of webapps 
log4j.logger.org.apache.myfaces.shared_impl.util.LocaleUtils=ERROR 

# Emits a spurious WARN during startup on /some-path/* security mappings 
log4j.logger.org.apache.catalina.deploy.SecurityCollection=ERROR 

# Prints the MBean Server ID 
log4j.logger.javax.management.MBeanServerFactory=WARN 

# Prints the RMI connection URL 
log4j.logger.javax.management.remote.rmi.RMIConnectorServer=WARN 
log4j.logger.javax.management.remote.JMXServiceURL=WARN 

# Prints various stuff during startup 
log4j.logger.org.apache.juddi.registry.RegistryServlet=WARN 

# Prints various stuff when the portal is used 
log4j.logger.org.apache.pluto.portalImpl.Servlet=WARN 

# Prints stuff for AJAX calls 
log4j.logger.uk.ltd.getahead.dwr.impl.DefaultConfiguration=WARN 
log4j.logger.uk.ltd.getahead.dwr.impl.ExecuteQuery=WARN 
log4j.logger.uk.ltd.getahead.dwr.util.Logger=WARN 

답변

50

:

는 다음과 같은 특성 파일이 어떻게 표시되는지를 보여줍니다.

log4j.appender.FRED=org.apache.log4j.RollingFileAppender 
log4j.appender.FRED.File=/path/to/fred.log 
log4j.appender.FRED.layout=org.apache.log4j.PatternLayout 

log4j.appender.DEREK=org.apache.log4j.RollingFileAppender 
log4j.appender.DEREK.File=/path/to/derek.log 
log4j.appender.DEREK.layout=org.apache.log4j.PatternLayout 

log4j.additivity.com.myname.fred=false 
log4j.additivity.com.myname.derek=false 

log4j.logger.com.myname.fred=DEBUG, FRED 
log4j.logger.com.myname.derek=DEBUG, DEREK 

업데이트 : 아래 라인을 추가해야하는지 확인하십시오. RFREDDEREK를 제외한 모든 로그를 일반 로그 파일이

log4j.rootLogger=DEBUG, R, FRED, DEREK 

.

+0

와우, 빠른 답변, 감사합니다. 나는 지금 그것을 시험 할 것이고 그것이 효과가 있다면 받아 들여진 대답으로 표시 할 것이다. –

+0

XML 구성으로 어떻게 할 수 있습니까? –

4
log4j.logger.com.myname.fred=LEVEL, appenderNameForFred 
log4j.logger.com.myname.derek=LEVEL, appenderNameForDerek 
관련 문제