c# - Log4net 不记录到数据库

标签 c# asp.net-mvc log4net

为了开始登录 .NET 项目,我添加了 log4net。 当尝试记录数据时,日志将写入本地文件,但不会写入数据库。

很可能错误出现在 log4net.config 中,因为我没有看到任何错误。我找不到似乎发现任何错误...

Global.asax.cs

[assembly: log4net.Config.XmlConfigurator(Watch = true)]    

创建日志的 Controller

private static readonly log4net.ILog log = log4net.LogManager.GetLogger(nameof(SettingController));  

log.InfoFormat($"Some Info");

log4net.config

<configuration>
  <log4net>
    <root>
      <level value="ALL" />
      <appender-ref ref="RollingFileAppender" />
      <appender-ref ref="ADONetAppender" />
    </root>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Logfile.txt" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="5MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %leveADONetAppenderl %logger - %message%newline" />
      </layout>
    </appender>

    <appender name="ADONetAppender" type="log4net.Appender.ADONetAppender">
      <bufferSize value="1" />

      <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=null" />
      <connectionString value="server=myServerName; Integrated Security=True; database=myDatabaseName" />

      <commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[User],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @user, @message, @exception)" />
      <parameter>
        <parameterName value="@log_date" />
        <dbType value="DateTime" />
        <layout type="log4net.Layout.RawTimeStampLayout" />
      </parameter>
      <parameter>
        <parameterName value="@thread" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%thread" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@log_level" />
        <dbType value="String" />
        <size value="50" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%level" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@logger" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%logger" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@user" />
        <dbType value="String" />
        <size value="50" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%user" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@message" />
        <dbType value="String" />
        <size value="4000" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%message" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@exception" />
        <dbType value="String" />
        <size value="2000" />
        <layout type="log4net.Layout.ExceptionLayout" />
      </parameter>
    </appender>
  </log4net>
</configuration>   

最佳答案

首先尝试登录到一个附加程序。在这种情况下,这是不起作用的。并且还启用内部调试:

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

...

    <system.diagnostics>
        <trace autoflush="true">
            <listeners>
                <add 
                    name="textWriterTraceListener" 
                    type="System.Diagnostics.TextWriterTraceListener" 
                    initializeData="C:\tmp\log4net.txt" />
            </listeners>
        </trace>
    </system.diagnostics>
</configuration>

Log4net FAQ

您可能会发现 ADONetAppender 中的参数映射等问题。从那里您可以解决问题,然后再次启用第二个附加程序。

关于c# - Log4net 不记录到数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46521879/

相关文章:

Log4Net配置日志级别

c# - Windows Phone 7 - iCal 生成器 - C#

c# - 随机矩阵的最佳类型 - 需要来源

c# - ServiceStack.Text 和 Twitter JSON

asp.net-mvc - Controller 实例上的 HttpContext 在 ASP.net MVC 中为空

c# - DDD 中的每个服务类都有一个接口(interface)是一种好的设计实践吗?

javascript - 两个 jQuery/JavaScript 函数未被调用

c# - 如何使用只读用户访问 azure 应用程序服务的 log4net 日志文件夹

c# - task.run 异步方法中出现空引用错误

c#-4.0 - 获取 Log4Net ILog 实例的目录