1添加引用
2添加配置文件 log4net.xml
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" />
</layout>
</appender>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="INFO">
<param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
<param name="File" value="Logs/" />
<param name="AppendToFile" value="true"/>
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd.'info.log'" />
<param name="RollingStyle" value="Date"/>
<param name="MaxSizeRollBackups" value="10" />
<param name="MaximumFileSize" value="5MB" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="## %d [%t] %-5p %x %m %n"/>
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="INFO" />
<param name="LevelMax" value="INFO" />
</filter>
</appender>
<appender name="ErrorFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="ERROR">
<param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
<param name="File" value="Logs/" />
<param name="AppendToFile" value="true"/>
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd.'error.log'" />
<param name="RollingStyle" value="Date"/>
<param name="MaxSizeRollBackups" value="10" />
<param name="MaximumFileSize" value="5MB" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="WARN" />
<param name="LevelMax" value="ERROR" />
</filter>
</appender>
<appender name="DebugFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="ERROR">
<param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
<param name="File" value="Logs/" />
<param name="AppendToFile" value="true"/>
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd.'debug.log'" />
<param name="RollingStyle" value="Date"/>
<param name="MaxSizeRollBackups" value="10" />
<param name="MaximumFileSize" value="5MB" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="DEBUG" />
<param name="LevelMax" value="DEBUG" />
</filter>
</appender>
<root>
<level value="All" />
<appender-ref ref="LogFileAppender" />
<appender-ref ref="ErrorFileAppender"/>
<appender-ref ref="DebugFileAppender" />
<appender-ref ref="ConsoleAppender" />
</root>
</log4net>
3 添加LogHelper类
using log4net;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace WindowsService1
{
public static class LogHelper
{
public static void Info(object msg, params object[] parameters)
{
var log = LogManager.GetLogger("log4netlogger");
log.Info(msg);
}
public static void Debug(string msg)
{
var log = LogManager.GetLogger("log4netlogger");
log.Debug(msg);
}
public static void Error(string msg)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(msg);
}
public static void FormatError(string format, params object[] args)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(string.Format(format, args));
}
public static void Error(Exception ex)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(ex.Message, ex);
}
public static void Error(object msg, Exception ex)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(msg, ex);
}
public static void Warn(object msg, Exception ex)
{
var log = LogManager.GetLogger("log4netlogger");
log.Warn(msg, ex);
}
public static void Log(string msg)
{
Info(msg);
}
public static void Log(Exception ex)
{
Error(ex);
}
}
}
4使用
protected void Page_Load(object sender, EventArgs e)
{
//加载log4net配置
log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(AppDomain.CurrentDomain.BaseDirectory + @"\log4net.xml"));
try
{
LogHelper.Info("-----------1001CloudServer 停止运行!");
}
catch (Exception E) {
LogHelper.Error(E.Message);
}
}
5根目录下会多出一个logs文件夹