第一步,添加程序集引用
引用兩個包:log4net和Microsoft.Extensions.Logging.Log4Net.AspNetCore,這兩個包分別是log4net的程序集和微軟針對log4net日誌組件的擴展包。
第二步,添加log4net的配置文件
在Startup類的同級別目錄中添加log4net.config文件,內容參考如下:
<?xml version="1.0" encoding="utf-8"?> <log4net> <!-- Define some output appenders --> <appender name="rollingAppender" type="log4net.Appender.RollingFileAppender"> <file value="log\log.txt" /> <!--追加日誌內容--> <appendToFile value="true" /> <!--防止多線程時不能寫Log,官方說線程非安全--> <lockingModel type="log4net.Appender.FileAppender+MinimalLock" /> <!--可以爲:Once|Size|Date|Composite--> <!--Composite爲Size和Date的組合--> <rollingStyle value="Composite" /> <!--當備份文件時,爲文件名加的後綴--> <datePattern value="yyyyMMdd.TXT" /> <!--日誌最大個數,都是最新的--> <!--rollingStyle節點爲Size時,只能有value個日誌--> <!--rollingStyle節點爲Composite時,每天有value個日誌--> <maxSizeRollBackups value="20" /> <!--可用的單位:KB|MB|GB--> <maximumFileSize value="3MB" /> <!--置爲true,當前最新日誌文件名永遠爲file節中的名字--> <staticLogFileName value="true" /> <!--輸出級別在INFO和ERROR之間的日誌--> <filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="ALL" /> <param name="LevelMax" value="FATAL" /> </filter> <!--必須結合起來用,第一個只過濾出WARN,第二個拒絕其它其它日誌輸出--> <!-- <filter type="log4net.Filter.LevelMatchFilter"> <param name="LevelToMatch" value="WARN" /> </filter> <filter type="log4net.Filter.DenyAllFilter" />--> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/> </layout> </appender> <!-- levels: OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL --> <root> <priority value="ALL"/> <level value="ALL"/> <appender-ref ref="rollingAppender" /> </root> </log4net>
第三步,創建服務實例
第四步,使用