配置文件
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<!--Add Log4Net Section-->
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="log\\log.log" />
<footer value="by wqq" />
<param name="AppendToFile" value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="10MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<!--<conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />-->
<conversionPattern value="记录时间:%date 线程ID:[%thread] 日志级别:文件:所在行%l %c -5level 出错类:%logger property:[%property{NDC}] - 错误描述:%message%newline" />
<!--Time:%d %Info:%message%newline-->
<!-- %date [%thread] %-5level %logger - %message%newline-->
</layout>
</appender>
<logger name="LogTrace">
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
</logger>
</log4net>
</configuration>
[assembly: log4net.Config.XmlConfiguratorAttribute(ConfigFile = "log4net.config", Watch = true)]
public class LogHelper
{
private static readonly ILog _logger = LogManager.GetLogger("LogTrace");
public static void Info(string message)
{
_logger.Info(message);
}
public static void Debug(string message)
{
_logger.Debug(message);
}
%m(message):输出的日志消息,如ILog.Debug(…)输出的一条消息
%n(new line):换行
%d(datetime):输出当前语句运行的时刻
%r(run time):输出程序从运行到执行到当前语句时消耗的毫秒数
%t(thread id):当前语句所在的线程ID
%p(priority): 日志的当前优先级别,即DEBUG、INFO、WARN…等
%c(class):当前日志对象的名称,例如:
%f(file):输出语句所在的文件名。
%l(line):输出语句所在的行号。
%数字:表示该项的最小长度,如果不够,则用空格填充,如“%-5level”表示level的最小宽度是5个字符,如果实际长度不够5个字符则以空格填充。