当前位置: 首页 > news >正文

做网站英文编辑有前途吗提交网站收录入口

做网站英文编辑有前途吗,提交网站收录入口,中国政府采购网首页,秦都区建设局网站Nlog是什么? NLog是一个为.NET平台设计的灵活且免费的日志记录库。它适用于包括.NET Framework、.NET Core和.NET Standard在内的多种.NET环境。 Nlog有什么好处或者特点? 配置灵活:NLog允许开发者通过配置文件(通常是NLog.conf…

Nlog是什么?

NLog是一个为.NET平台设计的灵活且免费的日志记录库。它适用于包括.NET Framework、.NET Core和.NET Standard在内的多种.NET环境。

Nlog有什么好处或者特点?

  • 配置灵活:NLog允许开发者通过配置文件(通常是NLog.config)来设定日志记录的行为,如日志级别、输出目标等,而无需修改代码。配置更改可即时生效,无需重启应用。

  • 多目标记录:支持将日志信息输出到多个目的地(或称为“目标”),如控制台、文件系统、数据库、电子邮件、网络Socket等,这为日志管理和分析提供了便利。

  • 日志级别管理:定义了多个日志级别,包括Trace、Debug、Info、Warn、Error和Fatal,使得开发者可以根据情况记录不同重要性的信息,并且可以设定记录的最低和最高级别。

  • 性能优化:设计注重性能,确保在高负载环境下也能高效地记录日志。

  • 结构化日志记录:支持日志消息的结构化输出,便于日志数据的自动化处理和分析。

  • 模板变量与布局渲染器:提供了丰富的模板变量(如${date}, ${level}, ${message}等)和布局渲染器,使得日志信息的格式化更加灵活和强大。

  • 即时配置变更:可以在应用程序运行时动态改变日志配置,无需重新部署。

  • 扩展性:用户可以自定义日志目标、布局渲染器等,以满足特定需求。

  • 开源与社区支持:作为开源项目,NLog拥有活跃的社区支持,持续更新和改进,同时也鼓励用户贡献代码和插件。

快速上手

准备工作

因为接上篇文章,我的项目里已经使用了log4net,所以我们使用Nlog的话暂时先注释掉之前的log4net,如果你的项目是干净的,那就直接看下个步骤哇~~


安装依赖 NLog.Web.AspNetCore


准备NLog配置文件

新建xiaojinWebApplication\configFile\NLog.Config, 下面的配置项注释掉了数据库日志部分,大家可以自行去掉注释哦,等我的数据库搭建好以后我就把这个打开补充一下~

<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"autoReload="true"throwExceptions="false"internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log"><!-- optional, add some variableshttps://github.com/nlog/NLog/wiki/Configuration-file#variables--><variable name="myvar" value="myvalue"/><!--See https://github.com/nlog/nlog/wiki/Configuration-filefor information on customizing logging rules and outputs.--><targets><!--add your targets hereSee https://github.com/nlog/NLog/wiki/Targets for possible targets.See https://github.com/nlog/NLog/wiki/Layout-Renderers for the possible layout renderers.--><!-- <target name="AllDatabase" xsi:type="Database"dbProvider="System.Data.SqlClient.SqlConnection, System.Data.SqlClient"connectionString="Data Source=PC-202206030027;Initial Catalog=LogManager;Persist Security Info=True;User ID=sa;Password=sa123"commandText="insert into dbo.NLog (Application, Logged, Level, Message,Logger, CallSite, Exception) values (@Application, @Logged, @Level, @Message,@Logger, @Callsite, @Exception);"><parameter name="@application" layout="AspNetCoreNlog" /><parameter name="@logged" layout="${date}" /><parameter name="@level" layout="${level}" /><parameter name="@message" layout="${message}" /><parameter name="@logger" layout="${logger}" /><parameter name="@callSite" layout="${callsite:filename=true}" /><parameter name="@exception" layout="${exception:tostring}" /></target> --><target xsi:type="File" name="allfile" fileName="NLog\nlog-all-${shortdate}.log"layout="${longdate}|${logger}|${uppercase:${level}}|${message} ${exception}" /><!--同样是将文件写入日志中,写入的内容有所差别,差别在layout属性中体现。写入日志的数量有差别,差别在路由逻辑中体现--><!-- <target xsi:type="File" name="ownFile-web" fileName="NLog\nlog-my-${shortdate}.log"layout="${longdate}|${logger}|${uppercase:${level}}|${message} ${exception}" /><target xsi:type="Null" name="blackhole" /> --><!--Write events to a file with the date in the filename.<target xsi:type="File" name="f" fileName="${basedir}/logs/${shortdate}.log"layout="${longdate} ${uppercase:${level}} ${message}" />--></targets><rules><logger name="*" minlevel="Trace" writeTo="AllDatabase" /><!-- add your logging rules here --><!--路由顺序会对日志打印产生影响。路由匹配逻辑为顺序匹配。--><!--All logs, including from Microsoft--><logger name="*" minlevel="Trace" writeTo="allfile" /><!--Skip Microsoft logs and so log only own logs--><!--以Microsoft打头的日志将进入此路由,由于此路由没有writeTo属性,所有会被忽略--><!--且此路由设置了final,所以当此路由被匹配到时。不会再匹配此路由下面的路由。未匹配到此路由时才会继续匹配下一个路由--><logger name="Microsoft.*" minlevel="Trace"  final="true" /><!--上方已经过滤了所有Microsoft.*的日志,所以此处的日志只会打印除Microsoft.*外的日志--><logger name="*" minlevel="Trace" writeTo="ownFile-web" /><!--Write all events with minimal level of Debug (So Debug, Info, Warn, Error and Fatal, but not Trace)  to "f"<logger name="*" minlevel="Debug" writeTo="f" />--></rules>
</nlog>
配置项详解
  • 标签定义了一个NLog的配置文件。
  • xmlns属性定义了NLog的命名空间,xsi:schemaLocation属性指定了NLog的XSD文件的位置。
  • autoReload属性设置为true表示配置文件发生变化时会自动重新加载。
  • throwExceptions属性设置为false表示不会抛出异常。
  • internalLogLevel属性设置为Off表示关闭内部日志记录。
  • internalLogFile属性指定了内部日志文件的路径。
  • 标签用于定义变量,这里的myvar变量被定义为myvalue。
  • 标签定义了日志的目标,例如数据库、文件等。
  • 标签定义了一个名为AllDatabase的日志目标,它是一个数据库目标,使用SQL Server数据库。
  • dbProvider属性指定了数据库提供程序。
  • connectionString属性指定了数据库连接字符串。
  • commandText属性指定了SQL命令文本。
  • 标签定义了SQL命令中的参数。
  • 标签还定义了其他日志目标,例如文件目标。
  • 标签定义了日志记录的规则。
  • 标签定义了一个日志记录器,它指定了日志记录的级别和要写入的目标。
  • name属性指定了日志记录器的名称。
  • minlevel属性指定了日志记录的最小级别。
  • writeTo属性指定了要写入的日志目标。
  • final属性设置为true表示此规则是最终规则,不会再匹配后续规则。 通过这个配置文件,可以将日志记录到数据库和文件中,并且可以自定义日志记录的级别和路由逻辑。
注册日志组件

xiaojinWebApplication\Program.cs

 // Nlog---startbuilder.Logging.AddNLog("configFile/NLog.Config");// Nlog---end

添加日志记录代码

看过我log4net文章的小伙伴,这个步骤可以省略哦~~,我们在代码里添加下面的日志调用逻辑,例如:xiaojinWebApplication\Controllers\CommonInfoController.cs

  private readonly ILogger<CommonInfoController> _logger; // 方案一private readonly ILoggerFactory _ILoggerFactory; // 方案二public CommonInfoController(ILogger<CommonInfoController> logger, ILoggerFactory iLoggerFactory){_logger = logger;_logger.LogInformation("方案一 LogInformation; this is CommonInfoController 构造函数~");_logger.LogError("方案一LogError: this is CommonInfoController 构造函数~");_logger.LogWarning("方案一LogWarning: this is CommonInfoController 构造函数~");_logger.LogDebug("方案一LogDebug:this is CommonInfoController 构造函数~");_ILoggerFactory = iLoggerFactory; // 方案二ILogger<CommonInfoController> _loger2 = _ILoggerFactory.CreateLogger<CommonInfoController>();_loger2.LogInformation("方案二LogInformation; this is CommonInfoController 构造函数~");_loger2.LogError("方案二LogError: this is CommonInfoController 构造函数~");_loger2.LogWarning("方案二LogWarning: this is CommonInfoController 构造函数~");_loger2.LogDebug("方案二LogDebug:this is CommonInfoController 构造函数~");}/// <summary>/// 测试接口01/// </summary>/// <returns></returns>[HttpGet(Name = "getCommonInfo")]public CommonInfo getCommonInfo(){_logger.LogInformation("测试接口01~");_logger.LogError("测试接口01~");_logger.LogWarning("测试接口01~");_logger.LogDebug("测试接口01~");return new CommonInfo{Date = DateOnly.FromDateTime(DateTime.Now),Text = "getCommonInfo"};}

运行代码

查看日志

打开xiaojinWebApplication\bin\Debug\net8.0\NLog\nlog-all-2024-05-07.log

大功告成

好了,等我数据库搭建好以后,下篇文章会记录如何使用数据库记录日志,大家也可以直接把代码注释打开,记得修改一下数据库的默认配置哦~

学习参考:

  • 微软MVP-Eleven

结语

  • 今天就写到这里啦~
  • 小伙伴们,( ̄ω ̄( ̄ω ̄〃 ( ̄ω ̄〃)ゝ我们明天再见啦~~
  • 大家要天天开心哦

欢迎大家指出文章需要改正之处~
学无止境,合作共赢

在这里插入图片描述

欢迎路过的小哥哥小姐姐们提出更好的意见哇~~
http://www.hengruixuexiao.com/news/42814.html

相关文章:

  • 直播平台推广seo短视频加密路线
  • 做企业网站用什么cms最全bt搜索引擎
  • 怎样用jsp做网站 新手教程中国新闻社
  • wordpress同步发布优化搜索曝光次数的方法
  • 景安香港主机可以做几个网站百度做广告推广怎么样
  • 网站建设不开单什么是seo搜索
  • 网站建设维护公司资质设计公司
  • 网站的规划与建设课程设计seo白帽优化
  • 有可以花钱让人做问券的网站吗it培训班真的有用吗
  • 网站建设女王节文案线上营销推广方式有哪些
  • 网站设计模式有哪些同城推广平台有哪些
  • aardio 网站开发广告推广平台赚取佣金
  • 学校的网站怎么做的好企业培训考试
  • 怎么学习做网站网络营销有什么方式
  • 中小学门户网站建设网络营销形式
  • 企业怎么在网站上做宣传搜索引擎优化公司排行
  • wordpress安装显示空白页seozhun
  • 网站提交链接入口高端营销型网站
  • 服务类网站模板网络推广公司是做什么的
  • 手机网站开发 教程个人怎么做免费百度推广
  • 深圳网站建设外包公司哪家好市场推广方案范文
  • 做推文网站除了秀米还要什么软文营销
  • 北京网页制作培训学校xp优化大师
  • 衡阳做网站的上海百度seo点击软件
  • 免费b站不收费网站2023简述影响关键词优化的因素
  • 开通招聘网站如何做分录网络营销买什么好
  • 网站的根目录的路径google adwords
  • 网站开发的经验网站域名查询ip
  • 移动网站建设多少钱东莞网络营销推广软件
  • web网站开发工具软文推广什么意思