3.2 日志

基本使用

NuGet安装Microsoft.Extensions.Logging及Microsoft.Extensions.Logging.Consloe

using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;

ServiceCollection services = new ServiceCollection();
//向容器中增加注册日志服务
services.AddLogging(logBuilder => { logBuilder.AddConsole(); });
using (var sp = services.BuildServiceProvider())
{
//获得一个用于输出日志的对象,泛型类型一般使用当前的类,此时当前的类是Program
//这样在输出日志的时候会显示类名
var logger = sp.GetRequiredService<ILogger<Program>>();
logger.LogWarning("这是一条警告消息");
logger.LogError("这是一条错误消息");
string age = "abc";
logger.LogInformation("用户输入的年龄:{0}", age);
try
{
int i = int.Parse(age);
}
catch (Exception ex)
{
logger.LogError(ex, "解析字符串为int失败");
}
}
//LogTrace,LogDebug,LogInformation,LogWarning,LogError,LogCritical
//严重等级依次增高

使用NLog输出到文件

  1. NuGet安装NLog.Extensions.Logging
  2. 在官网拷贝配置文件,注意设置属性:如果较新则复制。
    ​NLog官网​​ 配置文件解释:rules节点下可以添加多个logger,每个logger都有名字(name属性),name是通配符格式的。2、logger节点的minlevel属性和maxlevel属性,表示这个logger接受日志的最低级别和最高级别。3、日志输出时,会从上往下匹配rules节点下所有的logger,若发现当前日志的分类名符合这个logger的name的通配符,就会把日志输出给这个logger。如果匹配多个logger,就把这条日志输出给多个logger。但是如果一个logger设置了final=“true”,那么如果匹配到这个logger,就不继续向下匹配其他logger了。
  3. ​services.AddLogging(logBuilder => { logBuilder.AddNLog(); });​知识点:
    archiveAboveSize为“单个日志文件超过多少字节就把日志存档”,单位为字节,这样可以避免单个文件太大,如果不设定maxArchiveFiles参数,则文件日志存档文件的数量会一直增加,而如果设定maxArchiveFiles参数后,则最多保存maxArchiveFiles指定数量个数的存档文件,旧的会被删掉;当然也可以不设置maxArchiveFiles参数,而设置maxArchiveDays参数,这样可以设定保存若干天的日志存档。