NetCore2.x 使用Log4Net(一)
前言:本章仅仅是Log4Net的基本简单的运用,后续章节会按照我的项目使用情况进行深入研究
1.项目搭建
- 新建一个基于.netCore2.x的Web项目 => 过程略
- 给新建项目安装log4net包(NuGet安装 ) => 过程略
2.添加配置文件 log4Net.config
配置文件路径暂时就放在根目录,我怕到时候读取不到(尽量少给自己找事)
2.1 配置文件内容
<?xml version="1.0" encoding="utf-8"?> <configuration> <log4net> <root> <level value="ALL" /> <appender-ref ref="RollingFile" /> </root> <appender name="RollingFile" type="log4net.Appender.RollingFileAppender"> <!--文件路径 如果不设置(去掉 value="Log")会默认保存到[App_Data]文件夹中--> <param name="File" value="Log"/> <!--追加到文件--> <param name="AppendToFile" value="true"/> <!--最多保留的文件数,设为"-1"则不限--> <param name="MaxSizeRollBackups" value="365"/> <!--写到一个文件--> <param name="StaticLogFileName" value="false"/> <!--文件名,按日期命名--> <param name="DatePattern" value="yyyyMMdd".log""/> <!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]--> <param name="RollingStyle" value="Date"/> <!--日志格式--> <layout type="log4net.Layout.PatternLayout"> <!--%newline输出的日志会换行 [%date{HH:mm:ss fff}]表示记录的时间 --> <conversionPattern value="[%date{HH:mm:ss fff}] %- %message%newline" /> <!--如果想自己设置格式就只需要--> <!--<conversionPattern value="%message"/>--> </layout> </appender> </log4net> </configuration>
ps:看不懂没关系,先用起来再说,没有直观体验,说了没有用
2.2 注册Log4Net服务
- 实现方式一
这是我看了网上大多数实现方式,是在 Startup.cs 中创建一个静态变量 ,然后在其它类中调用这个静态方法获取Log对象,如下:
public class Startup { public static ILoggerRepository repository { get; set; }
public Startup(IConfiguration configuration) { Configuration = configuration; repository = LogManager.CreateRepository("NETCoreRepository"); // 指定配置文件 XmlConfigurator.Configure(repository, new FileInfo("log4net.config")); } } public class HomeController : Controller { private ILog log; public HomeController(IHostingEnvironment hostingEnv) { this.log = LogManager.GetLogger(Startup.repository.Name, typeof(HomeController)); } public IActionResult Index() { log.Error("测试日志"); return View(); } }
ps: 我在想,既然都在使用netcore 为啥不将 ILog 注入的服务中,构造函数注入直接获得呢。其实最大的可能就是在获取 Log实例的时候传入一个参数 typeof(HomeController),请移驾到该博客
https://blog.csdn.net/lixwjava/article/details/45950559
在我的项目中,会对写日志进行二次封装,对输出格式会有一定规定,所以,我会将Log 直接注入service中,如何封装将在后续博客中详细分析。
- 实现方式二
在 Startup.cs 文件的 ConfigureServices 方法中添加代码,结果如下
public void ConfigureServices(IServiceCollection services) { services.Configure<CookiePolicyOptions>(options => { // This lambda determines whether user consent for non-essential cookies is needed for a given request. options.CheckConsentNeeded = context => true; options.MinimumSameSitePolicy = SameSiteMode.None; }); var repository = LogManager.CreateRepository("NETCoreLogRepository"); XmlConfigurator.Configure(repository, new FileInfo("log4net.config")); services.AddSingleton<ILog>(LogManager.GetLogger(repository.Name, typeof(Startup))); }
创建分为三步:
a.创建一个Log4Net 仓库 repository
b.指定该仓库的配置文件路径
c.创建一个Log 实例 注入到 Service中
2.2 使用方法
项目中需要写日志的地方直接构造函数注入,代码如下:
public class HomeController : Controller { public readonly ILog _log; public HomeController(ILog log) { _log = log; _log.Info("This is Info Info"); } }
以上,最简单的使用方式。下篇将介绍如何根据不同日志等级写入不同的文件中。
后记:后来想了一想,其实我们可以在将 ILoggerRepository 注入到services中而不是将ILog注入,在使用的地方就可以动态指定typeof,以便跟踪对象,反正就是不想用静态变量,如下:
public void ConfigureServices(IServiceCollection services) { services.Configure<CookiePolicyOptions>(options => { // This lambda determines whether user consent for non-essential cookies is needed for a given request. options.CheckConsentNeeded = context => true; options.MinimumSameSitePolicy = SameSiteMode.None; }); var repository = LogManager.CreateRepository("NETCoreLogRepository"); XmlConfigurator.Configure(repository, new FileInfo("log4net.config")); services.AddSingleton<ILoggerRepository>(repository)); } public class HomeController : Controller { public readonly ILog _log; public HomeController(ILoggerRepository repository) { _log = LogManager.GetLogger(repository.Name,typeof(HomeController)); _log.Info("This is Info Info"); } }