如何调试不在 Azure 应用服务上写入的 log4net

How can I debug log4net not writing on an Azure App Service

我刚刚将新版本的应用服务推送到 Azure。 运行 没问题,但在我的 REST 调用中返回错误。

问题是 log4net 没有写入日志数据库。这给了我一个问题 - 当日志记录不起作用时我如何看到出了什么问题(它以前是但似乎已在 2018 年 10 月 11 日停止工作。

我的配置是:

 <log4net>
    <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
      <bufferSize value="1" />
      <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      <connectionString value="Server=tcp:*****,1433;Database=Log4Net;User ID=***@***p;Password=*****;Trusted_Connection=False;Encrypt=True;Connection Timeout=30;" />
      <commandText value="INSERT INTO UpdateLog ([Date],[Level],[Message],[Exception],[RemoteHost],[Cookie],[Url],[QueryString],[Referrer],[RequestMethod],[ScriptPath],[UserAgent],[Domain],[CustomBlob]) VALUES                     (@log_date, @log_level, @message, @exception,@remote_host,@cookie,@url,@query_string,@referrer,@request_method,@script_path,@user_agent,@domain,@custom_blob)" />
      <parameter>
        <parameterName value="@log_date" />
        <dbType value="DateTime" />
        <layout type="log4net.Layout.RawTimeStampLayout" />
      </parameter>
...

Kudo 是我最喜欢的此类调查工具。通过使用 Kudo,您可以打开 AppService VM,您可以看到所有类型的日志(应用程序和 IIS)。

您还可以通过启用调试模式Check log4net 内部日志

<configuration>
<appSettings>
  <add key="log4net.Internal.Debug" value="true"/>
</appSettings>
</configuration>