.NET Core log4net 使用(转贴)
log4net?.NET Core 版使用,log4net 2.0.7版發(fā)布也有一段時(shí)間了,從2.0.6 版開始就已經(jīng)支持.NET Core。
之前有介紹NLog .NET Core版的使用,ASP.NET Core 開發(fā)-Logging 使用NLog 寫日志文件。
ASP.NET Core已經(jīng)內(nèi)置了日志支持,可以輕松輸出到控制臺(tái)。使用log4net 將日志寫入到文件及輸出控制臺(tái)。
?
.NET Core項(xiàng)目使用
新建一個(gè) .NET Core 項(xiàng)目,選擇控制臺(tái)應(yīng)用程序。
添加引用:
Install-Package log4net
?
使用簡(jiǎn)單配置,將日志輸出至控制臺(tái),跟之前.NET 版本略微有些區(qū)別,需要指定Repository 。
public static void Main(string[] args)
? ? ? ? {
? ? ? ? ? ? ILoggerRepository repository = LogManager.CreateRepository("NETCoreRepository");
? ? ? ? ? ? // 默認(rèn)簡(jiǎn)單配置,輸出至控制臺(tái)
? ? ? ? ? ? BasicConfigurator.Configure(repository);
? ? ? ? ? ? ILog log = LogManager.GetLogger(repository.Name,"NETCorelog4net");
?
? ? ? ? ? ? log.Info("NETCorelog4net log");
? ? ? ? ? ? log.Info("test log");
? ? ? ? ? ? log.Error("error");
? ? ? ? ? ? log.Info("linezero");
? ? ? ? ? ? Console.ReadKey();
? ? ? ? }
運(yùn)行程序顯示如下:
?
下面增加配置,讓其輸出至文件。
在項(xiàng)目中添加一個(gè)配置文件,這里添加一個(gè)log4net.config ,內(nèi)容如下:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
? <!-- This section contains the log4net configuration settings -->
? <log4net>
? ? <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
? ? ? <layout type="log4net.Layout.PatternLayout" value="%date [%thread] %-5level %logger - %message%newline" />
? ? </appender>
? ??
? ? <appender name="FileAppender" type="log4net.Appender.FileAppender">
? ? ? <file value="log-file.log" />
? ? ? <appendToFile value="true" />
? ? ? <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" />
? ? ? <staticLogFileName value="false" />
? ? ? <datePattern value="yyyyMMdd'.log'" />
? ? ? <maxSizeRollBackups value="10" />
? ? ? <maximumFileSize value="1MB" />
? ? ? <layout type="log4net.Layout.PatternLayout">
? ? ? ? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
? ? ? </layout>
? ? </appender>
?
? ? <!-- Setup the root category, add the appenders and set the default level -->
? ? <root>
? ? ? <level value="ALL" />
? ? ? <appender-ref ref="ConsoleAppender" />
? ? ? <appender-ref ref="FileAppender" />
? ? ? <appender-ref ref="RollingLogFileAppender" />
? ? </root>
?
? </log4net>
</configuration>
這里定義了三個(gè)?Appender,都會(huì)起作用,然后日志級(jí)別ALL 所有的日志都會(huì)記錄。
更改Program.cs 代碼如下:
public static void Main(string[] args)
? ? ? ? {
? ? ? ? ? ? ILoggerRepository repository = LogManager.CreateRepository("NETCoreRepository");
? ? ? ? ? ? XmlConfigurator.Configure(repository, new FileInfo("log4net.config"));
? ? ? ? ? ? ILog log = LogManager.GetLogger(repository.Name,"NETCorelog4net");
?
? ? ? ? ? ? log.Info("NETCorelog4net log");
? ? ? ? ? ? log.Info("test log");
? ? ? ? ? ? log.Error("error");
? ? ? ? ? ? log.Info("linezero");
? ? ? ? ? ? Console.ReadKey();
? ? ? ? }
加了指定配置文件。運(yùn)行程序會(huì)生成一個(gè)文件夾和一個(gè)文件,因?yàn)橹匦露x了ConsoleAppender,控制臺(tái)輸出也有所不同。
?
ASP.NET Core項(xiàng)目使用
在ASP.NET Core 使用也是一樣,可以在Program.cs或Startup.cs 中指定Repository,然后控制器或中間件中獲取對(duì)象使用。
以下代碼是在Startup 構(gòu)造函數(shù)中初始化log4net
public class Startup
? ? {
? ? ? ? public static ILoggerRepository repository { get; set; }
? ? ? ? public Startup(IHostingEnvironment env)
? ? ? ? {
? ? ? ? ? ? var builder = new ConfigurationBuilder()
? ? ? ? ? ? ? ? .SetBasePath(env.ContentRootPath)
? ? ? ? ? ? ? ? .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
? ? ? ? ? ? ? ? .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)
? ? ? ? ? ? ? ? .AddEnvironmentVariables();
? ? ? ? ? ? Configuration = builder.Build();
? ? ? ? ? ? repository = LogManager.CreateRepository("NETCoreRepository");
? ? ? ? ? ? XmlConfigurator.Configure(repository, new FileInfo("log4net.config"));
? ? ? ? }
然后在Configure 中加了一個(gè)記錄日志
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory){ var log = LogManager.GetLogger(repository.Name,typeof(Startup));log.Info("test");?
在HomeController 也增加了:
private ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HomeController));
? ? ? ? public IActionResult Index()
? ? ? ? {
? ? ? ? ? ? log.Info("index view");
? ? ? ? ? ? log.Error("Controller Error");
? ? ? ? ? ? return View();
? ? ? ? }
運(yùn)行應(yīng)用結(jié)果如下,然后對(duì)應(yīng)的文件會(huì)有日志記錄。
?
?
對(duì)于輸出中文亂碼,需要增加編碼引用,以及代碼。NLog 那篇文章有介紹。寫到日志文件是沒有問題的。
?
參考文檔:
http://logging.apache.org/log4net/release/manual/configuration.html
http://logging.apache.org/log4net/release/config-examples.html
原文地址:http://www.cnblogs.com/linezero/p/log4net.html
轉(zhuǎn)載于:https://www.cnblogs.com/ppkkqq/p/6477612.html
總結(jié)
以上是生活随笔為你收集整理的.NET Core log4net 使用(转贴)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python与R的区别和联系
- 下一篇: ie下js不执行的几种可能