一.准备工作:
1.日志组件Log4net:
①Nuget引入程序包;
这里安装log4net,由Apache公司发布的。
②准备好配置文件;
安装好log4net包后,这里还要配和配置文件一起使用;
导入配置文件:
具体的配置文件如下:
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<!-- Define some output appenders -->
<appender name="rollingAppender" type="log4net.Appender.RollingFileAppender">
<file value="log4\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>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
</layout>
</appender>
<!--SqlServer形式-->
<!--log4net日志配置:http://logging.apache.org/log4net/release/config-examples.html -->
<appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
<!--日志缓存写入条数 设置为0时只要有一条就立刻写到数据库-->
<bufferSize value="0" />
<connectionType value="System.Data.SqlClient.SqlConnection,System.Data.SqlClient, Version=4.6.1.3, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
<connectionString value="Data Source=DESKTOP-2DUF58Q\SQLEXPRESS;Initial Catalog=ZhaoxiFlowerDb2;Persist Security Info=True;User ID=sa;Password=123456" />
<commandText value="INSERT INTO Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
</appender>
<root>
<!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
<!--OFF:0-->
<!--FATAL:FATAL-->
<!--ERROR: ERROR,FATAL-->
<!--WARN: WARN,ERROR,FATAL-->
<!--INFO: INFO,WARN,ERROR,FATAL-->
<!--DEBUG: INFO,WARN,ERROR,FATAL-->
<!--ALL: DEBUG,INFO,WARN,ERROR,FATAL-->
<priority value="ALL"/>
<level value="ALL"/>
<appender-ref ref="rollingAppender" />
<appender-ref ref="AdoNetAppender_SqlServer" />
</root>
</log4net>
注意:这里要将该配置文件的属性设置为“始终复制”;
然后重新编译一下。
③配置读取配置文件生效;
到这里我们需要到Program.cs文件中使我们的配置生效;
同时还需要引入Nuget程序集(Microsoft.Extensions.Logging.Log4Net.AspNetCore):
同时写入配置文件路径:
到这,我们继续添加一个新的控制器SecondController,在对应此控制器添加一个视图;
④注入得到log4net实例开始写日志;
开始在SecondController中注入实例对象:
注意:这里在注入实例对象时,用到了依赖注入;
using Microsoft.AspNetCore.Mvc;
namespace Advanced.NET6.Project.Controllers
{
public class SecondController : Controller
{
private readonly ILogger<SecondController> _Logger;
private readonly ILoggerFactory _LoggerFactory;
public SecondController(ILogger<SecondController> logger,ILoggerFactory
loggerFactory)
{
this._Logger = logger;
this._Logger.LogInformation($"{this.GetType().Name}被构造了。。。_Logger");
this._LoggerFactory = loggerFactory;
ILogger<SecondController> _Logger2=
this._LoggerFactory.CreateLogger<SecondController>();
_Logger2.LogInformation($"{this.GetType().Name}被构造了。。。_Logger2");
}
public IActionResult Index()
{
ILogger<SecondController> _Logger3 =
this._LoggerFactory.CreateLogger<SecondController>();
_Logger3.LogInformation($"{this.GetType().Name}被构造了。。。_Logger3");
this._Logger.LogInformation($"Index 被执行了。。。");
return View();
}
}
}
启动项目:
首先访问我们的Second/Index;
在我们的运行窗口可以看到:
然后打开我们的项目文件夹:
可以看到这里多出来一个log4文件(这里的文件路径在bin/debug下);
点进去打开就可以看到我们的日志了:
通过日志,我们在开发项目的时候,就可以及时的发现问题,使我们的系统保持一个稳定性。