0

我想将所有内容保存在日志文件中,并接收每封邮件包含 512 条消息的邮件。

RollingFileAppender 工作正常。但是在电子邮件中,我有时会收到 1 封邮件,有时会收到 4 封邮件(不是同一条)。

我也试过 MemoryAppender。我还有 1-2 条消息在队列中,仅此而已。

我尝试了“有损” SmtpAppender,结果是一样的。我应该改变什么?

我的配置在这里

<log4net>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="c:\temp\log-" />
  <bufferSize value="0" />
  <appendToFile value="true" />
  <rollingStyle value="Composite" />
  <param name="DatePattern" value="yyyy.MM.dd'.log'" />
  <maxSizeRollBackups value="-1" />
  <maximumFileSize value="10MB" />
  <staticLogFileName value="false" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date %-5level - %message%newline" />
  </layout>
</appender>
<appender name="SmtpAppender" type="log4net.Appender.SmtpAppender">
  <bufferSize value="512" />
  <lossy value="false" />
  <authentication value="Basic" />
  <to value="test@test.com" />
  <from value="test@test.com" />
  <username value="test@test.com" />
  <password value="xxxxx" />
  <subject value="My subject" />
  <smtpHost value="mail.test.com" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date %-5level - %message%newline" />
  </layout>
</appender>
<root>
  <level value="ALL" />
  <appender-ref ref="RollingLogFileAppender" />
  <appender-ref ref="SmtpAppender" />
</root>
</log4net>
4

1 回答 1

0

以下 appender 配置对我有用(我一次收到 6 条日志消息):

    <appender name="SmtpAppender" type="log4net.Appender.SmtpAppender">
        <to value="name@server.com" />
        <from value="name@server.com" />
        <subject value="Log Email" />
        <smtpHost value="email.test.com" />
        <bufferSize value="5" />
        <lossy value="false" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%property{log4net:HostName} :: %date %level %logger [%thread] - %message%newline" />
        </layout>
    </appender>

您的日志消息可能有多行吗?

于 2012-11-16T00:04:38.890 回答