配置Grails以邮寄生产环境中生成的所有异常

时间:2009-11-03 15:38:25

标签: exception logging grails log4j

问题:

  • 如何配置Grails以发送包含生产环境中生成的所有log4j错误消息(包括例外)的电子邮件?

值得注意的是:

1 个答案:

答案 0 :(得分:7)

解决方案是将以下内容添加到Config.groovy的log4j部分:

log4j = {
  ...
  appenders {
    console name:'stdout', layout:pattern(conversionPattern: '[%r] %c{2} %m%n')
    if (grails.util.Environment.current == grails.util.Environment.PRODUCTION) {
      def patternLayout = new org.apache.log4j.PatternLayout()
      patternLayout.setConversionPattern("[%r] %c{2} %m%n")
      def mailAppender = new org.apache.log4j.net.SMTPAppender()
      mailAppender.setFrom("from@example.com")
      mailAppender.setTo("to@example.com")
      mailAppender.setSubject("An log4j error has been generated in the production environment")
      mailAppender.setSMTPHost("your-smtp-host")
      mailAppender.setLayout(patternLayout)
      appender name:'mail', mailAppender
    }
  }
  root {
    error 'stdout', 'mail'
    additivity = true
  }
  ...
}

另外将sun-javamail.jar和activation.jar添加到lib / -folder。

此配置已经过测试,可按预期工作。