亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Log4net中的RollingFileAppender解析

系統(tǒng) 2148 0

Log4日志組件的應用確實簡單實用,在比較了企業(yè)庫和Log4的日志功能后,個人覺得Log4的功能更加強大點.補充說明下,我使用的企業(yè)庫是2.0版本,Log4net是1.2.1版本的.

在Log4net的應用上,已經(jīng)有人做了說明分析了,在本文中,主要解析下Log4net中的RollingFileAppender的應用.

主要參考了Log4net的幫助文檔.在項目中的log4net-1.2.10\doc文件下有.


RollingFileAppender主要是基于FileAppender構建的,很多屬性方法都是繼承于FileAppender,所以在選項設置上,也有許多是相同的.

下面的例子使日志文件名為log.txt,日志文件名是以文件大小進行變換的,如果舊日志文件大小到100KB時,就會變換文件名為log.txt.1,log.txt.2,log.txt.3...,一直到10為止

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">??
??????? <!--日志文件名-->
??? <file value="log.txt"/>
??? <!--是否在文件中追加-->
??? <appendToFile value="true"/>
??? <!--按照文件的大小進行變換日志文件-->
??? <rollingStyle value="Size"/>
??? <!--最大變換數(shù)量-->
??? <maxSizeRollBackups value="10"/>
??? <!--最大文件大小-->
??? <maximumFileSize value="100KB"/>
??? <!--日志文件名是否為靜態(tài)-->
??? <staticLogFileName value="true"/>
??? <layout type="log4net.Layout.PatternLayout">
??????? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline"/>
??? </layout>
</appender>
下面的例子以時間周期變換日志文件名,每分鐘都改變日志的文件名,日志文件名為logfileyyyyMMdd-HHmm,這里補充說明下,如果要在這個文件名后面加上.log后綴,必須使用轉義字符,比如<datePattern value="yyyyMMdd-HHmm&quot;.log&quot;" />

<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
??????? <!--日志文件名開頭-->
??? <file value="logfile" />
??? <!--是否追加到文件-->
??? <appendToFile value="true" />
??? <!--變換的形式為日期-->
??? <rollingStyle value="Date" />
??? <!--日期的格式-->
??? <datePattern value="yyyyMMdd-HHmm" />
??? <layout type="log4net.Layout.PatternLayout">
??????? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
??? </layout>
</appender>
下面的例子綜合使用使用日期和文件大小變換日志文件名。

<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
??? <!--日志文件名開頭-->
??? <file value="logfile" />
??? <!--是否追加到文件-->
??? <appendToFile value="true" />
??? <!--混合使用日期和文件大小變換日志文件名-->
??? <rollingStyle value="Composite" />
??? <!--日期的格式-->
??? <datePattern value="yyyyMMdd" />
??? <!--最大變換數(shù)量-->
??? <maxSizeRollBackups value="10" />
??? <!--最大文件大小-->
??? <maximumFileSize value="1MB" />
??? <layout type="log4net.Layout.PatternLayout">
??????? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
??? </layout>
</appender>
下面例子是在每次程序運行的時候,都會備份原先的日志文件,當運行的日志文件大于50G的時候才會變換日志文件名。

<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
??? <!--日志文件名-->
??? <file value="logfile.txt" />
??? <!--不追加到原文件-->
??? <appendToFile value="false" />
??? <!--以日志文件大小變換文件名-->
??? <rollingStyle value="Size" />
??? <!--最大變換數(shù)量,-1為不限制-->
??? <maxSizeRollBackups value="-1" />
??? <!--最大文件大小-->
??? <maximumFileSize value="50GB" />
??? <layout type="log4net.Layout.PatternLayout">
??????? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
??? </layout>
</appender>
下面是RollingFileAppender類中的部分Public Instance Properties(公共屬性)的說明,沒有全部測試,難免謬誤,如果你知道,請不要吝嗇告寫。
CountDirection : 定義當前文件是最小編號的文件還是最大編號的文件。默認為-1,總是以更小的編號。
datePattern : DateFormatter日期格式,string類型。
Encoding : 就是文件的編碼,默認為Default,就是程序本身的編碼了。
FilterHead : 分割符頭部。
ImmediateFlush : 表示是否立即輸出到文件,布爾型的。
LockingModel : 文件鎖類型,RollingFileAppender本身不是線程安全的,如果在程序中沒有進行線程安全的限制,可以在這里進行配置,確保寫入時的安全。有兩中類型:FileAppender.ExclusiveLock 和 FileAppender.MinimalLock
Name : 設置本Appander的名稱。
SecurityContext : 比較少應用,對日志進行加密只類的,使用SecurityContextProvider轉換。(對日志的保密要求比較高的時候應該可以應用上吧,Log4考慮的還挺周全)
Threshold : 設置內容級別的,比如:DEBUG,INFO等等。

?

在Log4net的配置中有兩種方法是等價的:
<param name="File" value="log.txt" /> 和
<File value="log.txt" />
個人更傾向后者。在一些數(shù)據(jù)庫上的應用時還有許多Param呢。

?

小結
Log4的應用遠不止這些,幫助文件也是很詳盡的,在程序級還是配置級都有相關例子。在整理了一個RollingFileAppender就花了我不少工夫。如果有機會接觸到其他的內容,我會繼續(xù)整理出來。

?

本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/much0726/archive/2009/01/07/3725563.aspx

Log4net中的RollingFileAppender解析


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲欧美另类在线视频 | 久久亚洲日本不卡一区二区 | 狠狠色丁婷婷综合久久 | 亚洲视频区 | 精品一区二区久久久久久久网精 | 久久久日本精品一区二区三区 | 伊人在线 | 在线资源站 | 日韩欧美一区二区三区不卡 | 宅男噜噜噜66一区二区 | 四虎国产精品永久地址49 | 日韩高清成人 | 国精品在亚洲_欧美 | 国产在线麻豆一区二区 | 网友自拍视频悠悠在线 | 伊人久久在线视频 | jizzjizz亚洲女人 | 男人猛躁女人成人免费视频 | 国产精品久久久久久久久久妇女 | 亚洲va在线va天堂成人 | 国产精品麻豆高清在线观看 | 日韩特黄| 97影院在线观看 | 变态捡到女婴h养成调教 | 桃色网站入口 | 天天爽夜夜爽人人爽 | 亚洲欧美精品国产一区色综合 | 天堂一区二区在线观看 | 五月综合色 | 日韩精品免费一区二区三区 | 国产成人精品无缓存在线播放 | 亚洲精品福利一区二区 | 一本大道久久香蕉成人网 | 国产日本亚洲 | 手机在线看片国产日韩生活片 | 九九热热 | 国产免费一区二区三区香蕉精 | 欧美精品影视 | 日日夜夜精品视频 | 四虎成人欧美精品在永久在线 | 国产免费小视频 |