1

我正在使用 log4net 来记录和发送电子邮件。我需要根据不同的流程发送不同配置的不同邮件。例如,当我的一个方法完成处理时,它会向 X 发送一封邮件,当我的服务成功完成时,它会向 Y 发送另一封邮件。
我认为我需要使用不同的附加程序和过滤器,但我无法到达正确配置它们。

我尝试了以下方法并尝试应用 StringMatchFilter,以便包含“强制”的消息不会传递给 Y,而包含“成功”的消息不会传递给 X,但没有运气。我也不确定这种过滤是否是进行这种配置的正确方法。

<log4net>

    <appender name="ManFieldMailAppender" type="log4net.Appender.SmtpAppender,log4net">
        <evaluator type="log4net.Core.LevelEvaluator">
            <threshold value="WARN"/>
        </evaluator>
        <filter type="log4net.Filter.LevelRangeFilter">
            <levelMin value="WARN" />
            <acceptOnMatch value="true" />
        </filter>
        <filter type="log4net.Filter.StringMatchFilter">
            <stringToMatch value="successfully" />
            <acceptOnMatch value="false" />
        </filter>
        <filter type="log4net.Filter.DenyAllFilter" />
        <to value="x@xxx.com" />
        <from value="aaa@aaa.com" />
        <subject value="Products not made online" />
        <smtpHost value="Host" />
        <authentication value="1"/>
        <username value="uid" />
        <password value="pwd" />
        <port value="25"/>
        <bufferSize value="1" />
        <lossy value="false" />
        <layout type="log4net.Layout.PatternLayout,log4net">
            <conversionPattern value="%newline %date %message%newline%newline%newline" />
        </layout>
    </appender>

    <appender name="ServiceFinishedMailAppender" type="log4net.Appender.SmtpAppender,log4net">
        <evaluator type="log4net.Core.LevelEvaluator">
            <threshold value="WARN"/>
        </evaluator>
        <filter type="log4net.Filter.LevelRangeFilter">
            <levelMin value="WARN" />
            <acceptOnMatch value="true" />
        </filter>
        <filter type="log4net.Filter.StringMatchFilter">   
            <stringToMatch value="mandatory" />
            <acceptOnMatch value="false" />
        </filter>
        <filter type="log4net.Filter.DenyAllFilter" />
        <to value="y@yyy.com" />
        <from value="bbb@bbb.com" />
        <subject value="Product Publish Service has successfully finished operating" />
        <smtpHost value="Host" />
        <authentication value="1"/>
        <username value="uid" />
        <password value="pwd" />
        <port value="25"/>
        <bufferSize value="1" />
        <lossy value="false" />
        <layout type="log4net.Layout.PatternLayout,log4net">
            <conversionPattern value="%newline %date %message%newline%newline%newline" />
        </layout>
    </appender>

    <root>
        <appender-ref ref="ManFieldMailAppender" />
        <appender-ref ref="ServiceFinishedMailAppender"/>
    </root>

</log4net>

你认为问题是什么?

谢谢你。

4

1 回答 1

1

首先,evaluator告诉缓冲附加程序何时刷新。从您的配置来看,我认为您没有缓冲。(所以你也可以去掉bufferSizeandlossy参数)。我看到您的附加程序过滤器链具有所需的DenyAllFilters. 但是,您的根记录器配置未显示任何级别,请尝试添加

<root>
    <level value="ALL" />
    <!-- appender-refs as normal -->
</root>

一般来说,我不会根据消息文本决定登录到特定的附加程序。看起来您有一个用于其中一项操作的高级服务类。如果您对需要发送的其他消息有相同的内容,并且您通过 typename 命名记录器,则可以为每个记录器指定一个附加程序。

<logger name="MyCompany.Product.Whatever">
    <level value="WARN" />
    <appender name="ManFieldMailAppender" type="...">
        <!-- the rest of the configuration, without filtering goes here -->
    </appender>
</logger>

<logger name="MyCompany.Services.Publish">
    <level value="WARN" />
    <appender name="ServiceFinishedMailAppender" type="...">
        <!-- the rest of the configuration, without filtering goes here -->
    </appender>
</logger>
于 2011-06-16T04:29:55.453 回答