1.Nuget 引入

NLog

NLog.Web.AspNetCore

NLog.Database(写入数据库使用)

2.创建nlog.config

注意数据库连接字符串需要配置TrustServerCertificate=True;不然会有认证问题

<?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"
autoReload="true"
internalLogLevel="Info"
internalLogFile="c:\temp\internal-nlog-AspNetCore.txt"> <!-- enable asp.net core layout renderers -->
<extensions>
<add assembly="NLog.Web.AspNetCore"/>
<add assembly="NLog.Database"/>
</extensions> <!-- the targets to write to -->
<targets>
<target name="AllDatabase" xsi:type="Database"
dbProvider="Microsoft.Data.SqlClient.SqlConnection, Microsoft.Data.SqlClient"
connectionString="Data Source=.;Initial Catalog=LogTest;Persist Security Info=True;User ID=sa;Password=123;Encrypt=True;TrustServerCertificate=True;"
commandText="insert into dbo.NLogManager (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>
<!-- File Target for all log messages with basic details -->
<target xsi:type="File" name="allfile" fileName="c:\temp\nlog-AspNetCore-all-${shortdate}.log"
layout="${longdate}|${event-properties:item=EventId:whenEmpty=0}|${level:uppercase=true}|${logger}|${message} ${exception:format=tostring}" /> <!-- File Target for own log messages with extra web details using some ASP.NET core renderers -->
<target xsi:type="File" name="ownFile-web" fileName="c:\temp\nlog-AspNetCore-own-${shortdate}.log"
layout="${longdate}|${event-properties:item=EventId:whenEmpty=0}|${level:uppercase=true}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}|${callsite}" /> <!--Console Target for hosting lifetime messages to improve Docker / Visual Studio startup detection -->
<target xsi:type="Console" name="lifetimeConsole" layout="${MicrosoftConsoleLayout}" />
</targets> <!-- rules to map from logger name to target -->
<rules>
<!--All logs, including from Microsoft-->
<logger name="*" minlevel="Trace" writeTo="AllDatabase" />
<logger name="*" minlevel="Trace" writeTo="allfile" /> <!--Output hosting lifetime messages to console target for faster startup detection -->
<logger name="Microsoft.Hosting.Lifetime" minlevel="Info" writeTo="lifetimeConsole, ownFile-web" final="true" /> <!--Skip non-critical Microsoft logs and so log only own logs (BlackHole) -->
<logger name="Microsoft.*" maxlevel="Info" final="true" />
<logger name="System.Net.Http.*" maxlevel="Info" final="true" /> <logger name="*" minlevel="Trace" writeTo="ownFile-web" /> </rules>
</nlog>

3.注入Nlog服务

builder.Logging.ClearProviders();//删除所有其他关于日志的配置
builder.Logging.SetMinimumLevel(LogLevel.Trace);//指定级别
builder.Host.UseNLog();

4.简单使用

private readonly ILogger<HomeController> _logger;
private readonly ILoggerFactory _loggerfactoary;
public HomeController(ILogger<HomeController> logger, ILoggerFactory loggerfactoary)
{
_logger = logger;
_logger.LogInformation($"logger{this.GetType().FullName}被构造"); _loggerfactoary = loggerfactoary;
ILogger<HomeController> _logger2 = _loggerfactoary.CreateLogger<HomeController>();
_logger2.LogInformation($"logger2{this.GetType().FullName}被构造");
}

最新文章

  1. Nginx在线服务状态下平滑升级或新增模块的详细操作
  2. UWP&amp;WP8.1 重新绘制图片 WriteableBitmap用法 图片转byte[]数组,byte[]数组转图片
  3. Word2013创建目录
  4. openwrt刷机后配置PPPOE上网方法
  5. Android平板电脑开发— — —碎片
  6. linux:centos准备及安装
  7. centos查看设置端口开放状态
  8. MySQL与Oracle 差异比较之七用户权限
  9. poj 1191 矩形块的划分
  10. [转贴]从零开始学C++之STL(一):STL六大组件简介
  11. 购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(3)--Idetity,OWIN前后端验证
  12. 直接拿来用!最火的Android开源项目(三部完整版)
  13. Mybatis的@Options注解
  14. 用adb命令查看apk版本
  15. caffe︱深度学习参数调优杂记+caffe训练时的问题+dropout/batch Normalization
  16. 算法——算法时间复杂度的计算和大O阶的推导
  17. axure8.0激活
  18. 学号 20175329 2018-2019-3《Java程序设计》第四周学习总结
  19. PyXB: Python XML Schema Bindings
  20. JDBC连接MySql,配置url报错

热门文章

  1. 构造器与this、package、import关键字的使用
  2. rabbitmq原理和应用
  3. C# String.IsNullOrEmpty()方法的使用
  4. 五、docker网络
  5. 一台虚拟机,基于docker搭建大数据HDP集群
  6. JS 学习笔记(一)常用的字符串去重方法
  7. &lt;二&gt;掌握构造函数和析构函数
  8. RabbitMQ GUI客户端工具(RabbitMQ Assistant)
  9. perl 之 join和 split
  10. 第2-3-8章 分片上传和分片合并的接口开发-文件存储服务系统-nginx/fastDFS/minio/阿里云oss/七牛云oss