记录日志中的grails应用程序中的错误

时间:2013-05-17 12:18:06

标签: exception grails logging log4j

当我的Grails应用程序崩溃时,它会在错误页面上显示错误和堆栈跟踪,因为error.gsp页面包含以下代码段<g:renderException exception="${exception}“/&gt;。但是没有任何内容记录在日志文件中。< / p>

我该怎么改变?因为对于生产应用程序,我计划删除renderException,因为我不希望用户看到整个堆栈跟踪。

我的log4j设置如下:

appenders {
    rollingFile name:'catalinaOut', maxFileSize:1024, fileName:"${System.properties.getProperty('catalina.home')}/logs/mylog.log"
}

root {
    error 'catalinaOut'
    debug 'catalinaOut'
    additivity = true
}

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',
        'grails.app'

debug   'grails.app'

}

我正在开发中以grails run-app

运行该应用

1 个答案:

答案 0 :(得分:3)

我将这些设置用于基于控制台和文件的日志记录。如果您不想要/需要控制台,可以删除stdout。只需复制相应列表中的所有错误类。

log4j = {

    def loggerPattern = '%d %-5p >> %m%n'

    def errorClasses = [] // add more classes if needed
    def infoClasses = ['grails.app.controllers.myController'] // add more classes if needed
    def debugClasses = [] // add more classes if needed

    appenders {
        console name:'stdout', layout:pattern(conversionPattern: loggerPattern)
        rollingFile name: "file", maxFileSize: 1024, file: "./tmp/logs/logger.log", layout:pattern(conversionPattern: loggerPattern)
    }

    error   stdout: errorClasses, file: errorClasses
    info    stdout: infoClasses, file: infoClasses
    debug   stdout: debugClasses, file: debugClasses
}