原文:ASP.NET 5 入门 (3) – Logging

ASP.NET 5 理解和入门

建立和开发ASP.NET 5 项目

使用自定义配置文件

ASP.NET 5 入门 (3) – Logging

前几天就关注到汤姆大叔的相关文档: 解读ASP.NET 5 & MVC6系列(9):日志框架.

讲的已经很清楚了, 这里就不加累述了,那么换一个角度,在实现方案和代码开发方面谈下自己的理解.

理解ASP.NET5的Logging

ASP.NET 5的Logging我认为其实就是2句话:

  • Logging的使用: 应用内部的Logging统一使用Microsoft.Framework.Logging接口.
  • Logging的实现: 通过不同的代理类向不同的Logging实现技术分发应用内部产生的Log.

Logging的使用其实就是依托2个基本接口:  ILogger和ILoggerFactory.

Logging的实现其实就是通过实现不同的ILoggerProvider代理接口和其他技术对接.

如果还是不明白可以看下目前Microsoft.Framework.Logging的源码,就清楚了:

https://github.com/aspnet/Logging/tree/dev/src

我们可以看到Abstractions就是Logging的通用接口,而Console, Nlog和TraceSouce就是3个内部提供的代理类.目前能够使用的只有Console和TraceSource代理, 而NLog并没有提交, 不过根据这里面的代码,我相信针对其他Logging技术比如Log4Net,Serilog的代理类也并不难实现.

如何使用通用Logging框架

使用Logging框架一共分3步:

  1. 使用依赖注入获取ILoggerFactory实现.
  2. 利用ILoggerFactory构建ILogger实例
  3. 使用ILogger实例输出Log信息.

我们还是以最经典的Startup的Configurate函数为例:

public void Configure(IApplicationBuilder app){//利用最简单的GetService函数获取通过依赖注入获取ILoggerFactory实现var loggerfactory = (ILoggerFactory)app.ApplicationServices.GetService(typeof(ILoggerFactory));//创建logger实例var logger = loggerfactory.CreateLogger<Startup>();//输出一条Log信息logger.LogWarning("这是一条警告信息");}

那么这些输出的Log信息在那里显示呢,除了VS调试环境,很遗憾没有任何地方能看到这些信息,这是因为标准的Logging实现不实现任何输出,如果要想输出,必须加入各种代理类把Log分发出去.

加入Console代理

首先我们加入引用:

"Microsoft.Framework.Logging.Console": "1.0.0-beta4"

其次我们加入如下代码

var loggerfactory = (ILoggerFactory)app.ApplicationServices.GetService(typeof(ILoggerFactory));
// 加入Console代理
loggerfactory.AddConsole(minLevel:LogLevel.Information);

代理在加入在项目中只需要加一次,一般就在Configure函数中加入即可. 加入以上代码以后,所有从通用接口分发的Log信息都会显示在程序控制台上面,当然由于设置了minLevel属性,仅仅高于或等于Information等级的信息才会被显示.

加入TraceSource代理

如果仅仅是在控制台显示显然是不过瘾的,一般来说,我们会把log输出到文件,在目前的情况下我们只能通过TraceSource代理吧Log输出到文件. TraceSource是System.Diagnostics中的主要内容,大家应该并不陌生.

首先我们还是需要加入一些组件

"Microsoft.Framework.Logging.TraceSource": "1.0.0-beta4"

如果要让Core 5.0也支持,还必须加入

"System.Diagnostics.TextWriterTraceListener": "4.0.0-beta-22816"

实现的代码是(开发时自行加入所需的using语句):

var loggerfactory = (ILoggerFactory)app.ApplicationServices.GetService(typeof(ILoggerFactory));// Add trace source logger
var logFileStream = new FileStream("app.log", FileMode.Append);
var traceListenter = new TextWriterTraceListener(logFileStream)
{Filter = new EventTypeFilter(SourceLevels.Error | SourceLevels.Critical)
};
var source = new SourceSwitch("AppLog")
{Level = SourceLevels.All
};
loggerfactory.AddTraceSource(source, traceListenter);

根据以上代码,所有Error和Critical的Log信息会被输出到当前目录的app.log文件中去,如果要显示更多等级的信息请自行修改Filter.

该代理和Console一样,也只需要运行一次,同样建议在Configurate中运行.

其他代理的实现展望

其他的代理类目前是没有比较完整的实现,但我们可以预见到后续的实现方法其实并不难,就是:

  • 首先引入你使用的第三方Log实现,比如Log4Net,NLog,Serilog等.
  • 然后引入或者自行开发代理类, 一般这个代理类会为ILoggerFactory实现一个扩展函数 AddXXX() : 比如AddNlog , AddLog4Net , AddSeriLog 等等.
  • 最后在Configutate函数中调用这个扩展函数AddXXX() 函数把标准Logging分发到该第三方Log实现.

这就是目前ASP.NET 5 所提供的Logging分发思路和实现方案.

ASP.NET 5 入门 (3) – Logging相关推荐

  1. ASP.NET MVC入门到精通——Spring.net-业务层仓储

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 上一节,我们已经把项目框架的雏形搭建好了,那么现在我来开始业务实现,在业务实现的过程当中,不断的来完善我们现有的框架. 1.假设我们来做一个 ...

  2. 【翻译转载】【官方教程】Asp.Net MVC4入门指南(2):添加一个控制器

    2. 添加一个控制器 · 原文地址:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/adding-a-c ...

  3. Asp.Net MVC4入门指南(3):添加一个视图

    在本节中,您需要修改HelloWorldController类,从而使用视图模板文件,干净优雅的封装生成返回到客户端浏览器HTML的过程. 您将创建一个视图模板文件,其中使用了ASP.NET MVC ...

  4. ASP.NET AJAX入门系列(1):概述

    经常关注我的Blog的朋友可能注意到了,在我Blog的左边系列文章中,已经移除了对Atlas学习手记系列文章的推荐,因为随着ASP.NET AJAX 1.0 Beta版的发布,它们已经不再适用,为了不 ...

  5. ASP.NET Core 入门教程 2、使用ASP.NET Core MVC框架构建Web应用

    原文:ASP.NET Core 入门教程 2.使用ASP.NET Core MVC框架构建Web应用 一.前言 1.本文主要内容 使用dotnet cli创建基于解决方案(sln+csproj)的项目 ...

  6. 【转】ASP.NET AJAX入门系列

    ASP.NET AJAX入门系列将会写关于ASP.NET AJAX一些控件的使用方法以及基础知识,其中部分文章为原创,也有一些文章是直接翻译自官方文档,本部分内容会不断更新. 目录 ASP.NET A ...

  7. ASP.NET CORE 入门教程(附源码)

    ASP.NET CORE 入门教程 第一课 基本概念 基本概念 Asp.Net Core Mvc是.NET Core平台下的一种Web应用开发框架 符合Web应用特点 .NET Core跨平台解决方案 ...

  8. 16、ASP.NET MVC入门到精通——MVC过滤器

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 在ASP.NET MVC中有四种过滤器类型 Action 1.在ASP.NET MVC项目中,新建文件夹Filter,然后新建类MyCust ...

  9. 1、ASP.NET MVC入门到精通——新语法

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 在学习ASP.NET MVC之前,有必要先了解一下C#3.0所带来的新的语法特性,这一点尤为重要,因为在MVC项目中我们利用C#3.0的新特 ...

最新文章

  1. Java这个高级特性-泛型,很多人还没用过!
  2. Git_学习_06_ 放弃本地修改
  3. [转] log4j-over-slf4j与slf4j-log4j12共存stack overflow异常分析
  4. php小结,PHP编程小结
  5. MapReduce Java API-使用Partitioner实现输出到多个文件
  6. git中fatal: Authentication failed的问题
  7. 超级简便的容器化部署工具(使用 ASP.NET Core 演示)
  8. GT sport赛道详解 - Dragon Trail | 龙之径
  9. 分享几个Python小技巧函数里的4个小花招
  10. flink的测试sql怎么测试呢,不能每次都使用jar测试吧,那么sqk-client就来了
  11. 网页设计下拉菜单栏css代码,HTML+CSS实现导航条下拉菜单的示例代码
  12. 安卓端airplay实现IOS屏幕镜像
  13. OpenSSL下载及使用(生成公钥 私钥)
  14. 无损批量合并视频 附工具
  15. 台式计算机怎么进行打印机共享,台式机共享打印机的方法
  16. 微前端框架qiankun之原理与实战
  17. 4.16 使用可选颜色命令调整图像色彩 [原创Ps教程]
  18. iOS 制作推送证书的流程 超详细!!!!!
  19. C++中模板类的静态成员
  20. Java数据库JDBC——prepareStatement的用法和解释

热门文章

  1. USACO-Section2.1 Sorting a Three-Valued Sequence(排序)
  2. USACO-Section1.3 Milking Cows (区间问题)
  3. Java 集合List、Set、HashMap操作三(查找List中的最大最小值、遍历HashTable、List元素替换、List查找位置)
  4. XML相关的安全漏洞-XXE,XPATH小结(XXE注入、XPATH注入)
  5. 非常详细Redis数据库入门教程
  6. 9. OD-PEID的入门及BASIC(VB)开发的程序破解
  7. 沉淀再出发:PHP的中级内容
  8. 使用nginx简单实现负载均衡
  9. 按home键退出的activity可以不进入stop模式码_用了几年的iPhone,竟然不知道苹果手机还有“游戏模式”?...
  10. 【面试题】一文讲清,为啥redis单线程还有很高的性能?