【发布时间】:2011-01-18 13:18:35
【问题描述】:
我对此感到非常沮丧。
我正在尝试执行以下操作:
- 在 application.log 中记录所有应用程序相关的 INFO 或以上日志
- 了解控制 catalina.out 配置的因素
- 仅将 WARN 记录到 catalina.out
我在 ubuntu 上运行我的服务器,并且我有 tomcat 的默认配置,其中包括一个带有 logging.properties 的 conf 目录。我将此文件重命名为 l.p,这样它就不会发生冲突。 (不确定这是否是个好主意)
在我的配置文件中,我有:
def catalinaBase = System.properties.getProperty('catalina.base')
if (!catalinaBase) catalinaBase = '.' // just in case
def logDirectory = "${catalinaBase}${File.separator}logs"
println "Log Directory: ${logDirectory}"
log4j = {
appenders {
rollingFile name: 'applog', file: "${logDirectory}${File.separator}application.log", layout: pattern(conversionPattern: '%d{dd-MM-yyyy HH:mm:ss,SSS} %5p %c{1} - %m%n'), maxFileSize: 1024
}
error 'org.codehaus.groovy.grails.web.servlet', // controllers
'org.codehaus.groovy.grails.web.pages', // GSP
'org.codehaus.groovy.grails.web.sitemesh', // layouts
'org.codehaus.groovy.grails.web.mapping.filter', // URL mapping
'org.codehaus.groovy.grails.web.mapping', // URL mapping
'org.codehaus.groovy.grails.commons', // core / classloading
'org.codehaus.groovy.grails.plugins', // plugins
'org.codehaus.groovy.grails.orm.hibernate', // hibernate integration
'org.springframework',
'org.hibernate',
'net.sf.ehcache.hibernate'
warn 'org.mortbay.log'
info applog: 'grails.app'
root {
info 'applog'
}
}
结果,我得到了三个日志:
catalina.2011-01-17.log catalina.out localhost.2011-01-17.log
catalina.out 有以下输出:
Log Directory: /var/lib/tomcat6/logs
log4j:WARN No appenders could be found for logger (org.apache.commons.beanutils.PropertyUtils).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
log4j:ERROR WARNING: Exception occured configuring log4j logging: Cannot invoke org.apache.log4j.FileAppender.setFile - argument type mismatch
我在日志文件目录中看不到application.log。任何帮助将不胜感激我对此感到非常沮丧。
还有一件事,在 Windows 中,所有内容都输出到控制台,并且在 .grails\1.3.5\projects\<appnmae>\tomcat 目录中创建了 application.log
【问题讨论】:
标签: linux tomcat grails groovy log4j