3.3 日志

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参数,这样可以设定保存若干天的日志存档。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

步、步、为营

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值