C# log4net日志庫的用法小結(jié)
一、簡述
記--log4net日志開源庫的簡單使用:控制日志文件大小,日志文件個(gè)數(shù),滾動(dòng)式覆蓋,自由控制日志打印等級(jí)
例子打包:
http://xiazai.jb51.net/202110/yuanma/Log4netTest_jb51.rar
http://xiazai.jb51.net/202110/yuanma/apache-log4net-source_jb51.rar
http://xiazai.jb51.net/202110/yuanma/apache-log4net-binaries_jb51.rar
二、下載log4net
直接使用log4net源碼或直接使用log4net源碼編譯對應(yīng)的dll或直接使用log4net.dll
下載地址:http://logging.apache.org/log4net/download_log4net.html

例子直接使用其中4.5的dll。(請根據(jù)當(dāng)前環(huán)境的.net framework框架版本進(jìn)行選擇,請看右鍵項(xiàng)目--》屬性--》應(yīng)用程序--》目標(biāo)框架)

三、添加log4net.dll引用

四、添加日志配置log.config

編輯log.config內(nèi)容如下:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<log4net>
<appender name="MyAppender1" type="log4net.Appender.RollingFileAppender">
<file value="app.log" /> <!--日志文件名-->
<appendToFile value="true" /> <!--日志文件以追加方式進(jìn)行-->
<rollingStyle value="Size" /> <!--按文件大小進(jìn)行滾動(dòng)記錄,也可以按日期-->
<maxSizeRollBackups value="2" /> <!--最多兩個(gè)日志備份,app.log.1 app.log.2-->
<maximumFileSize value="8KB" /> <!--日志文件達(dá)到8KB就重新記一個(gè)文件-->
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<!--每一行日志輸出格式-->
<conversionPattern value="%date [%thread] (%file:%line) %-5level %logger - %message%newline" />
</layout>
</appender>
<logger name="Mylog1"> <!--代碼通過Mylog1獲取對應(yīng)的logger句柄-->
<level value="WARN" /> <!--比WARN等級(jí)低的不會(huì)輸出 日志等級(jí)由高到低:OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
<appender-ref ref="MyAppender1" /> <!--啟用MyAppender1-->
</logger>
</log4net>
</configuration>
將配置同步更新到exe輸出路徑

五、在AssemblyInfo.cs文件中添加log4net.dll相關(guān)參數(shù)
在AssemblyInfo.cs文件末尾添加一行(其中的log.config就是步驟四添加的配置文件)
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log.config", Watch = true)]

六、測試?yán)?/h2>
6.1 測試代碼
namespace Log4netTest
{
public partial class Form1 : Form
{
//Mylog1對應(yīng)log.config種的一個(gè)logger名稱
public static readonly log4net.ILog mLogger = log4net.LogManager.GetLogger("Mylog1");
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
mLogger.Error("APP Start");
mLogger.Debug("logDebug");
mLogger.Info("logInfo");
mLogger.Warn("logWarn");
mLogger.Error("logError");
mLogger.Error(this);
}
}
注:代碼種的Mylog1對應(yīng)log.config中的一個(gè)logger名稱
6.2 效果
控制日志文件大小,日志文件個(gè)數(shù),滾動(dòng)式覆蓋,控制日志打印等級(jí)為WARN。


七、附
7.1 更多日志配置
http://logging.apache.org/log4net/release/manual/configuration.html

7.2 日志格式
%m(message):輸出的日志消息,如ILog.Debug(…)輸出的一條消息
%n(new line):換行
%d(datetime):輸出當(dāng)前語句運(yùn)行的時(shí)刻
%r(run time):輸出程序從運(yùn)行到執(zhí)行到當(dāng)前語句時(shí)消耗的毫秒數(shù)
%t(thread id):當(dāng)前語句所在的線程ID
%p(priority): 日志的當(dāng)前優(yōu)先級(jí)別,即DEBUG、INFO、WARN…等
%c(class):當(dāng)前日志對象的名稱,例如:
%f(file):輸出語句所在的文件名。
%l(line):輸出語句所在的行號(hào)。
%數(shù)字:表示該項(xiàng)的最小長度,如果不夠,則用空格填充,如“%-5level”表示level的最小寬度是5個(gè)字符,如果實(shí)際長度不夠5個(gè)字符則以空格填充
7.3 日志配置
appender、logger標(biāo)簽可多個(gè),不是一一對應(yīng)關(guān)系的

到此這篇關(guān)于C# log4net日志庫的簡單使用的文章就介紹到這了,更多相關(guān)C# log4net使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

