标签: xmlconfigurator

log4net初始化

我看起来很难复制,但不管它看起来多么基本,都要问下面的内容,让它一劳永逸地清楚!

在使用64位W7上的VS28KSP1上的log4net版本1.2.10.0的全新控制台应用程序中,我有以下代码: -

using log4net;
using log4net.Config;

namespace ConsoleApplication1
{
    class Program
    {
        static readonly ILog _log = LogManager.GetLogger(typeof(Program));
        static void Main(string[] args)
        {
            _log.Info("Ran");
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

在我app.config,我有:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Program.log" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="1MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%username] %date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> …
Run Code Online (Sandbox Code Playgroud)

.net log4net initialization xmlconfigurator log4net-configuration

28
推荐指数
1
解决办法
2万
查看次数

Log4Net EventLogAppender未记录到自定义事件日志

添加了一个EventLogAppender,如下所示:

<appender name="eventLogAppender" type="log4net.Appender.EventLogAppender,log4net" >
    <mapping>
        <level value="ERROR" />
        <eventLogEntryType value="Error" />
    </mapping>
    <mapping>
        <level value="DEBUG" />
        <eventLogEntryType value="Information" />
    </mapping>
    <mapping>
        <level value="INFO" />
        <eventLogEntryType value="Information" />
    </mapping>
    <mapping>
        <level value="WARN" />
        <eventLogEntryType value="Warning" />
    </mapping>
    <logName value="NewLogName" />
    <applicationName value="AppName" />
    <layout type="log4net.Layout.PatternLayout,log4net">
        <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
    </layout>
</appender>
Run Code Online (Sandbox Code Playgroud)

它创建新的日志,NewLogName并添加应用程序名称为的Windows事件,AppName但它将事件添加到Application日志而不是NewLogName.

我已在注册表中更改权限,并且应用程序名称位于注册表中的正确位置.有任何想法吗?

.net log4net xmlconfigurator

6
推荐指数
1
解决办法
4278
查看次数

如何在使用XmlConfigurator加载后以编程方式设置log4net LockingModel?

我有这个XML log4net配置:

  <log4net>
    <appender name="myAppender" type="log4net.Appender.RollingFileAppender">
      <file value="mylog.txt" />
    </appender>
    <root>
      <level value="DEBUG" />
        <appender-ref ref="myAppender" />
    </root>
  </log4net>
Run Code Online (Sandbox Code Playgroud)

我使用下面的C#行加载此配置,它运行良好:

log4net.Config.XmlConfigurator.Configure(path);
Run Code Online (Sandbox Code Playgroud)

问题:现在我想设置lockingModelMinimalLock.以编程方式,而不是XML.
怎么做?

这相当于添加<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />XML配置.

c# log4net xmlconfigurator

5
推荐指数
1
解决办法
5383
查看次数