热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

asp.netcore日志组件

日志介绍Logging的使用1.appsettings.json中Logging的介绍Logging的配置信息是保存在appsettings.json配置文件中的。因为之前介绍配置文件的
日志介绍

Logging的使用

1. appsettings.json中Logging的介绍

Logging的配置信息是保存在appsettings.json配置文件中的。因为之前介绍配置文件的时候我们使用的是appsettings.Development.json这个文件,所以在介绍Logging的时候我们也用它吧。

通过上图可以看到Logging节点,下面有两个子节点IncludeScopes和LogLevel。

IncludeScopes表示是否要使用日志作用域。在同一个作用域下的日志都会打上相同的标记,告诉我们这些日志是一组的,属于同一个作用域。在using块中使用,就像我们使用数据库事物操作一样。

LogLevel表示日志的级别,默认Warning。如果我们在代码中输出Info级别的日志,是不会有任何输出的。因为设置的级别是Warning,只会输出高于和等于Warning级别的日志。

日志的级别:Trace ->Debug-> Information ->Warning-> Error-> Critical,从左往右由低到高。

另外我们还可以指定命名空间和命名空间的日志级别。如下图中的System和Microsoft。当遇到System.*或者Microsoft.*开头的命名空间,日志级别采用Error的级别。我在这里设为Error级别,因为如果级别设置太低的话,每次运行程序都会有一大堆的追踪日志。不便于我们查找想要的日志信息。

废话不多说了,接下来通过实例一一介绍。

2.注入Logger

因为Logger是.net core自带的日志输出组件,而且默认已经存在于DI容器中,所以我们仅需通过构造方法注入Logger即可。

3.演示普通日志

F5运行程序,通过多次刷新页面,控制台窗口输出结果:

4.演示日志级别

控制台输出结果:

可以看到trace级别的日志没有输出。因为appsettings.json中设置的Default级别为debug,高于trace级别。

5.演示日志作用域

首先创建一个使用控制台作为输出媒介的Logger工厂,同时第一个参数表示日志的默认级别为debug,第二个参数表示使用作用域记录日志。

然后就是创建一个指定全名(SongLou.Web.Controllers.HomeController)的Logger实例。

最后使用using括起来,指定作用域。

输出见下图:

Nlog的使用

1.简单介绍

NLog是一个基于.NET平台编写的类库,我们可以使用NLog在程序中添加完善的调试追踪代码。根据喜好配置其表现样式之后发送到一个或多个输出目标(target)中。配置简单灵活。

NLog遵从BSD license,即允许商业应用且完全开放源代码。任何人都可以免费使用并对其进行测试,然后通过邮件列表反馈问题以及建议。

NLog日志输出目标:控制台、文本文件、数据库、Email、消息队列等。虽然有这么多输出目标,但是我只会介绍控制台和文本文件,有精力的同学可以研究其它的输出目标。

2.targets和rules

NLog包含最基本的两大元素:targets和rules。target用来配置日志的输出类型(type)、输出目标(fileName)、输出格式(layout)等。rules用来配置日志的输出规则,比如:info级别的日志输出到哪个target、设置日志的最低级别。由writeTo来指定输出到哪个target,具体的值为target的name。下面会详细介绍。

3.安装Nlog包

通过NuGet安装下面两个包,同时注意版本。

NLog.Extensions.Logging版本是:1.0.0-rtm-rc7

NLog.Web.AspNetCore版本是:4.5.0-rc3

4.添加nlog.config

如果要使用NLog,仅仅安装它的包是不行的,还需要我们进行相关配置。

先在根目录下添加一个空的nlog.config配置文件,如下图:

5.修改Startup.cs

引入两个命名空间:

using NLog.Extensions.Logging;

using NLog.Web;

修改Configure方法。添加对IloggerFactory的引用,并加入代码:

loggerFactory.AddNLog();

env.ConfigureNLog("nlog.config");

具体看下图:

6.NLog输出到控制台

Nlog的配置非常灵活,功能也很强大,所以注定配置会有很多。但是我们目前只关注在控制台输出日志,其它的先不要考虑。下面给出最简单的配置,如下图:

配置文件完成之后,添加测试代码,如下图:

直接F5运行,结果如下:

日志按照我们配置的输出格式输出到控制台了。因为这个演示没有写文件,只是将日志输出到控制台,所以它的fileName我们没有配置,接下来的写入到文件的演示将会用到fileName。

7.NLog输出到文件

具体配置如下图:

对配置做下简单介绍。target节点中的name表示target的名字,rules节点里面的writeTo属性会用到。type为file,表示日志的输出类型是文件。fileName表示日志输出到哪个目录的哪个文件,没有会自动创建。layout表示日志内容的格式:“日期|大写的日志级别|具体日志信息|异常信息”。

再来看看rules。logger节点的name属性表示程序中的具体类型。打个比方,我只想在NLogController这个类里面做日志,我就可以设置name=”SongLou.Web.Controllers. NLogController”,我这里设置的是*号,表示在任何一个地方都可以将日志写入到文件。writeTo指定具体的target,我这里设置的是name为logfile的target。

可以添加多个target,也可以添加多个logger。多个logger可以指定同一个target。

修改代码,如下图:

配好之后,直接按F5运行,这个时候,我们在相应的目录就可以看到NLog成功写入文件:

8.NLog滚动日志介绍

什么是滚动日志?

在生产环境中,日志不可能保存在一个文件里面。随着文件内容越来越多,单个文件也会越来越大,不仅在打开时不方便,对我们查找具体的日志也不方便。如果保存在很多小的文件里面,随着程序运行的时间越来越久也会产生很多个文件,这样做也不好。特别是现在有很多日志搜集工具,只要能保证日志搜集工具能够搜集到所有的日志即可。然后再同步到我们的数据库(ElasticSearch),比如用logstash就可以做日志搜集。

为了更好的理解,我画了一张图。假如日志文件最多保存5个,每个大小1K。当5个文件都满的时候,NLog会把最后一个文件删除,前面4个文件往后移动并对文件名做+1操作重新命名。而新产生的日志就会放在file1文件里。

关于滚动日志有几个属性做下简单介绍。

archiveFileName:滚动文件名称,可以设置按规则命名

archiveAboveSize:滚动文件的大小,以字节为单位

archiveNumbering:Rolling,轮转;Sequence,升序

concurrentWrites:同一个主机是否允许多个线程并发写日志

maxArchiveFiles:保留文件个数

keepFileOpen:有一种特殊的方法保持文件打开状态,设为true有助于提高性能,因为设置为true之后concurrentWrites就不起作用了。

具体配置如下:

代码无需做任何改动,按F5运行。多刷新几次页面,当文件的大小达到1K时,会自动创建一个新的文件。如下图:

 


推荐阅读
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • vue引入echarts地图的四种方式
    一、vue中引入echart1、安装echarts:npminstallecharts--save2、在main.js文件中引入echarts实例:  Vue.prototype.$echartsecharts3、在需要用到echart图形的vue文件中引入:   importechartsfrom"echarts";4、如果用到map(地图),还 ... [详细]
  • 一个建表一个执行crud操作建表代码importandroid.content.Context;importandroid.database.sqlite.SQLiteDat ... [详细]
  • 本文总结了一些开发中常见的问题及其解决方案,包括特性过滤器的使用、NuGet程序集版本冲突、线程存储、溢出检查、ThreadPool的最大线程数设置、Redis使用中的问题以及Task.Result和Task.GetAwaiter().GetResult()的区别。 ... [详细]
  • 本文介绍了如何使用 Node.js 和 Express(4.x 及以上版本)构建高效的文件上传功能。通过引入 `multer` 中间件,可以轻松实现文件上传。首先,需要通过 `npm install multer` 安装该中间件。接着,在 Express 应用中配置 `multer`,以处理多部分表单数据。本文详细讲解了 `multer` 的基本用法和高级配置,帮助开发者快速搭建稳定可靠的文件上传服务。 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • Spring框架中枚举参数的正确使用方法与技巧
    本文详细阐述了在Spring Boot框架中正确使用枚举参数的方法与技巧,旨在帮助开发者更高效地掌握和应用枚举类型的数据传递,适合对Spring Boot感兴趣的读者深入学习。 ... [详细]
  • 深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案
    深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案 ... [详细]
  • 在Android平台中,播放音频的采样率通常固定为44.1kHz,而录音的采样率则固定为8kHz。为了确保音频设备的正常工作,底层驱动必须预先设定这些固定的采样率。当上层应用提供的采样率与这些预设值不匹配时,需要通过重采样(resample)技术来调整采样率,以保证音频数据的正确处理和传输。本文将详细探讨FFMpeg在音频处理中的基础理论及重采样技术的应用。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 解决Jenkins编译过程中ERROR: Failed to Parse POMs的问题
    在使用Jenkins进行自动化构建时,有时会遇到“ERROR: Failed to parse POMs”的错误。本文将详细分析该问题的原因,并提供有效的解决方案。 ... [详细]
  • iOS开发 - 解决导航栏子视图损坏问题
    本文介绍了一个在Xcode 5.0.2和iOS 7模拟器环境下,使用Storyboard创建CoreData CRUD应用时遇到的导航栏子视图损坏问题及其解决方案。 ... [详细]
  • 在多线程并发环境中,普通变量的操作往往是线程不安全的。本文通过一个简单的例子,展示了如何使用 AtomicInteger 类及其核心的 CAS 无锁算法来保证线程安全。 ... [详细]
  • Java高并发与多线程(二):线程的实现方式详解
    本文将深入探讨Java中线程的三种主要实现方式,包括继承Thread类、实现Runnable接口和实现Callable接口,并分析它们之间的异同及其应用场景。 ... [详细]
  • 当使用 `new` 表达式(即通过 `new` 动态创建对象)时,会发生两件事:首先,内存被分配用于存储新对象;其次,该对象的构造函数被调用以初始化对象。为了确保资源管理的一致性和避免内存泄漏,建议在使用 `new` 和 `delete` 时保持形式一致。例如,如果使用 `new[]` 分配数组,则应使用 `delete[]` 来释放内存;同样,如果使用 `new` 分配单个对象,则应使用 `delete` 来释放内存。这种一致性有助于防止常见的编程错误,提高代码的健壮性和可维护性。 ... [详细]
author-avatar
迷人的小刀
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有