我刚刚将我的应用服务的新版本推送到 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,可以打开应用服务 VM,并查看所有类型的日志(应用程序和 IIS)。
您还可以通过启用调试模式来检查log4net内部日志
<configuration>
<appSettings>
<add key="log4net.Internal.Debug" value="true"/>
</appSettings>
</configuration>