在我们项目开发的过程中,使用.net 6自带的日志系统有时是不能满足实际需求的,比如有的时候我们需要将日志输出到第三方平台上,最典型的应用就是在各种云平台上,为了集中管理日志和查询日志,通常会选择对应平台的日志sdk进行集成。使用rilog提供的多种sink,可以实现将日志写入不同云平台或者是非云平台的日志存储中去,这是我们这篇文章讲要研究的内容。
我们将为todolist
添加一个方便替换和扩展的日志策略,简单来说就是在与具体第三方打交道的infrastructure
项目中实际设置使用的日志服务,并在api项目中进行依赖注入,方便在整个应用程序中无具体日志配置感知地使用日志服务。
查阅rilog
的官方文档和一些示例后确定,
我们要做的事情有这么几件:
引入rilog.aspnetcore
包(很多文章或者教程里都让你根据需要使用的sink去继续引入类似rilog.si我是神经病歌词nk.file
之类的包,但是实际上rilog.aspnetcore
包的依赖项里已经包含了file这个sink,所以实际上没有必要再去添加一次);二是需要为rilog的logger对象提供一个loggerconfiguration
,可以以代码的方式进行配置,也可以通过加载.json文件的方式进行配置,看自己的需求和对配置热更新的有3d电影原理没有独特的要求决定;在程序启动构造webapplicationbuilder
对象的时候声明urilog();
在需要使用日志的地方注入ilogger<t>对象即可,我们一般是在构造函数里进行注入,当然也可以选择其他两种注入方式。 好了,了解了原理,接下来一步就是想一下我们要在哪里做这几件事。
在中,我提到了clean architecture
,里面有一条原则可以理解为:如果系统需要与外部(第三方)系统进行集成或交互,那么具体的集成工作应该放入infrastructure
层进行处理,而程序的其他部分只对外部服务进行抽象的使用。好处是今后如果需要替换第三方系统,比如原本日志是写到本地文件里,后来有了上云和日志集中化处理的需求,需要将日志服务对接到诸如azure app rvice logging
或者aws cloudwatch
,那么我们只需要去修改(扩展)infrastructure中进行日志具体配置的逻辑就可以了。虽然日志服务本身相对比较简单,还不能很好地体现这个优点,我们姑且遵循这个原则,将配置工作放到infrastructure
里面去。
我们在todolist.infrastructure项目中新增一个文件夹,取名log,在其中新建文件configurelogprovider.cs,实现一个针对webapplicationbuilder
的扩展方法,为了演示在这里配置的扩展性,我多用了一个appttings.json
中的字段来控制配置过程,缺失的包需要安装一下。
using microsoft.aspnetcore.builder;using microsoft.extensions.configuration;using rilog;namespace todolist.infrastructure.log;public static class configurelogprovider{ public static void configurelog(this webapplicationbuilder builder) { if (builder.configuration.getvalue<bool>("ufiletolog")) { // 配置同时输出到控制台和文件,并且指定文件名和文件转储方式(形如log-20211219.txt格式),转储文件保留的天数为15天,以及日志格式 // 配置enrich.fromlogcontext()的目的是为了从日志上下文中获取一些关键信息诸如用户id或请求id,我们的应用中暂时不使用这些。 rilog.log.logger = new loggerconfiguration() .enrich.fromlogcontext() .writeto.console() .writeto.file( "logs/log-.txt", outputtemplate: "{timestamp:yyyy-mm-dd hh:m罗志祥的发型m:ss.fff zzz} [{level:u3}] {message:lj}{newline}{exception}", rollinginterval: rollinginterval.day, retainedfilecountlimit: 15) .createlogger(); } el { // 仅配置控制台日志 rilog.log.logger = new loggerconfiguration() .enrich.fromlogcontext() .writeto.console() .createlogger(); } // 使用rilog作为日志框架,注意这里和.net 5及之前的版本写法是不太一样的。 builder.host.urilog(); }}
在todolist.api项目的main.cs中,使用该扩展方法:
using todolist.infrastructure.log;var builder = webapplication.createbuilder(args);// add rvices to the container.// 配置日志builder.configurelog();builder.rvices.addcontrollers();// ... 省略以下
并向appttings.development.json文件中添加用于测试的配置项:
{ "logging": { "loglevel": { "default": "information", "microsoft.aspnetcore": "warning" } }, "ufiletolog": true}
嗯……我把第二篇文章结束时删除的示例weatherforecastcontroller.cs
和weatherforecast.cs
又加回来了。controller
中已经注入了ilogger<weatherforecastcontroller>,
我们就在示例的接口里试一下:
[httpget(name = "getweatherforecast")]public ienumerable<weatherforecast> get(){ // 记录日志 _logger.loginformation($"maybe this log is provided by rilog..."); 正能量的故事 return enumerable.range(1, 5).lect(index => new weatherforecast { date = datetime.now.adddays(index), temperaturec = random.shared.next(-20, 55), summary = su软开度mmaries[random.shared.next(summaries.length)] }) .toarray();}
好了,到此为止我们就可以验证一下了。
运行todolist.api
项目,和第二篇文章一样,我们使用hoppscotch
测试示例接口,观察控制台和日志文件的输出内容和格式:
控制台输出
文件输出
总结:
在这篇文章中,我向大家展示了如何在.net 6 web api项目中添加第三方日志服务框架,下一篇文章将会引入数据存储服务。
到此这篇关于.net 6开发todolist应用引入第三方日志库的文章就介绍到这了,更多相关使用.net 6 todolist引入第三方日志库内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 12:26:00,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/55e4ea772668266ce17e401b57fccf78.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:.NET 6开发TodoList应用引入第三方日志库.doc
本文 PDF 下载地址:.NET 6开发TodoList应用引入第三方日志库.pdf
留言与评论(共有 0 条评论) |