max*_*max 1 java jboss alert log4j jboss6.x
我们使用 jBoss 日志记录并让它最终工作 - 现在我们遇到了问题,我们不想在每次出现错误时发送电子邮件。如果抛出定义的异常,我们只想发送一封电子邮件。例如 com.myproject.exceptions.fatal.ProjectFatalException
“jboss-logging.xml”中的默认定义如下所示:
<log4j-appender name="SMTP" class="org.apache.log4j.net.SMTPAppender">
<error-manager>
<only-once/>
</error-manager>
<level name="ERROR"/>
<properties>
<property name="to">admin@myhost.domain.com</property>
<property name="from">nobody@myhost.domain.com</property>
<property name="subject">JBoss Sever Errors</property>
<property name="SMTPHost">localhost</property>
<property name="bufferSize">10</property>
</properties>
<formatter>
<pattern-formatter pattern="%d %-5p [%c] (%t) %m%n"/>
</formatter>
</log4j-appender>
Run Code Online (Sandbox Code Playgroud)
虽然这个答案晚了将近 3 个月,但希望这在未来仍然对您和其他人有所帮助。您可以使用 将StringMatchFilter电子邮件限制为特定错误。
您可以使用SMTPAppender和filters的组合来解决此问题。在您的jboss-log4j.xml:-
<!-- add the SMTPAppender -->
<appender name="SMTP" class="org.apache.log4j.net.SMTPAppender">
<errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%c] (%t) %m%n"/>
</layout>
<param name="Threshold" value="ERROR"/>
<param name="To" value="someone@somewhere.com"/>
<param name="From" value="someone@somewhere.com"/>
<param name="Subject" value="JBoss Alert: ProjectFatalException"/>
<param name="SMTPHost" value="some.smtp.host"/>
<param name="BufferSize" value="512"/>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="error" />
<param name="LevelMax" value="fatal" />
</filter>
<filter class="org.apache.log4j.varia.StringMatchFilter">
<param name="StringToMatch" value="ProjectFatalException" />
<param name="AcceptOnMatch" value="true" />
</filter>
<filter class="org.apache.log4j.varia.DenyAllFilter"/>
</appender>
<!-- add the SMTP appender to your project package category -->
<category name="com.myproject">
<priority value="ERROR"/>
<appender-ref ref="SMTP"/>
</category>
Run Code Online (Sandbox Code Playgroud)
作为旁注,通常将 SMTP 等慢附加程序添加为 ASYNC 是个好主意。默认情况下它是同步的。
| 归档时间: |
|
| 查看次数: |
1165 次 |
| 最近记录: |