我看起来很难复制,但不管它看起来多么基本,都要问下面的内容,让它一劳永逸地清楚!
在使用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
添加了一个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.
我已在注册表中更改权限,并且应用程序名称位于注册表中的正确位置.有任何想法吗?
我有这个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)
问题:现在我想设置lockingModel为MinimalLock.以编程方式,而不是XML.
怎么做?
这相当于添加<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />XML配置.