2

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

我怎样才能改变这个?因为对于生产应用程序,我计划删除,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

4

1 回答 1

3

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

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
}
于 2013-05-17T12:38:18.617 回答