Ошибка приложения sm4p log4net

У меня log4net настроен следующим образом

<appender name="RollingFile" type="log4net.Appender.RollingFileAppender">

  <!-- Edit to change your filename here -->
  <file value="Logs\\rolling.log" />

  <appendToFile value="true" />
  <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
  <rollingStyle value="Date" />
  <datePattern value=".yyyy-MM-dd'.log'" />
  <maximumFileSize value="10MB" />

  <!-- %identity used for ASP.NET app, %username used for windows app. You can leave them as is or remove one of them accordingly -->
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="[%date{dd MMM yyyy HH:mm:ss fff}] [%5level] (%identity-%username) %message%newline" />
  </layout>
</appender>

<appender name="SmtpAppender" type="log4net.Appender.SmtpAppender">
  <to value="***" />
  <from value="***" />
  <subject value="****" />
  <smtpHost value="localhost" />
  <bufferSize value="1" />
  <lossy value="true" />
  <evaluator type="log4net.Core.LevelEvaluator">
    <threshold value="ERROR"/>
  </evaluator>
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="[%date{dd MMM yyyy HH:mm:ss fff}] [%5level] (%identity-%username) %message%newline" />
  </layout>
</appender>

<root>
  <!-- Edit to change level of logging here, under normal conditions this should be set to INFO, use DEBUG level for verbose logging -->
  <level value="INFO" />
  <appender-ref ref="RollingFile" />
  <appender-ref ref="SmtpAppender" />
</root>

Приложение для прокрутки файлов работает нормально, однако приложение SMTP не работает со следующей ошибкой System.Net.Mail.SmtpException: Failure sending mail. ---> System.Net.WebException: Unable to connect to the remote server ---> System.Net.Sockets.SocketException: An attempt was made to access a socket in a way forbidden by its access permissions [::1]:25

Что я нахожу странным, так это то, что квадратные скобки в конце ошибки не содержат SMTP-хост из конфигурации. Я ожидал увидеть localhost там.

Я запускаю это против smtp4dev на моей локальной машине.

Спасибо!

1 ответ

Решение

Нотация [::1] - это способ обозначения петлевого адреса с помощью IPV6 (двойная нотация просто скрывает 0, не добавляя информацию к адресу), поэтому в сообщении просто говорится, что аппендер пытается связаться с localhost.

Что касается самой ошибки, это может быть связано с тем, что антивирус блокирует доступ к порту, который вы хотите использовать, или из-за брандмауэра, препятствующего подключению. Пожалуйста, проверьте, есть ли у вас сообщения о заблокированном доступе в этих приложениях.

Другие вопросы по тегам