log4日志内容换行_简易日志NuGet 日志包 SimpleLogger

『简易日志』NuGet 日志包 SimpleLogger

独立观察员 2020 年 7 月 7 日

一、概述

目前,.NET 框架下,主流的日志组件大致就是 Nlog 和 Log4Net 了,功能比较强大,但总感觉太重了,学习他们的配置规则也是个门槛。当然还有这两者的各种封装变种,以及似乎在 .NET Core 中比较流行的微软官方的 Microsoft.Extensions.Logging,具体没怎么使用过,不好评价。(说到变种,本人曾经也改造过一个 log4net 的版本:https://gitee.com/dlgcy/YTLog ,感兴趣的可以试试)。

其实,对于个人项目或者较小的项目,我们实际只需要将日志内容写入文本文件即可。本人制作的这个 “简易日志 (SimpleLogger)” 包里面包含的代码逻辑,最开始也就是简单地写入文本,后来经过实际使用的演化,做了各种优化,添加了一些实用的特性,感觉用着还不错。正所谓独乐乐不如众乐乐,于是将其打包上传到微软的包管理库 NuGet 中,大家可以使用试试,相互交流。核心代码已托管在码云了:https://gitee.com/dlgcy/dotnetcodes/blob/dlgcy/DotNet.Utilities/ 日志 / LogHelper.cs 。

二、使用方法

1、配置(可选)

配置不是必须的,只有当对于目录、前缀、单条最大长度、保留天数这几项有定制需求时才需要调用 LogHelper.Config () 方法进行配置:

f98def63fe438afc8627cb17b50564b3.png

该方法应该在应用程序的启动初期调用,且之后不再调用,建议在程序入口的静态方法中调用。

2、使用

使用 “简易日志 (SimpleLogger)” 记录日志是很容易的,只需调用 LogHelper.Write () 方法即可:

f7842d6f9db887827a6698da2b64d340.png

可以看到最少只需传递一个日志内容参数即可。另外还支持是否空行,以及记录调用方信息。

如果之前程序中都是 Console.Write() 这样的,您也无需批量替换,LogHelper 中附带了将控制台信息重定向到日志的辅助类(ConsoleWriter)供您使用:

3f5223789d2bdbe81d0970441ab863c4.png

三、特色

总体来说,” 简易日志 (SimpleLogger)” 拥有如下特色:

(1) 免配置使用;

(2) 便捷配置:指定路径、前缀、单条最大长度、保留天数;

(3) 按日期分文件、自动记录时间和调用信息、连续重复内容仅计数。

着重说一下 “连续重复内容仅计数” 特性,意思就是如果有连续的重复内容,则 “简易日志 (SimpleLogger)” 不会直接输出多条重复内容,仅输出第一条,后续的内容只记录时间和重复到第几次,并且不换行,直到碰到下一条不同的内容为止,效果见下一节。

四、效果展示

不同程序配置到不同目录:

d26f40ae3c0592e4dedf97ffb73b29bc.png

日志文件按照日期分开:

7b9439e297a7b7e076f7df3f9de69eda.png

自动记录时间和调用信息:

f5b376469c9e950eb8af96df3d6b5c3a.png

清理指定天数之前的日志(需配置,默认不清理):

cf959df5b7a0b95f58cd43957a949ee7.png

单条最大长度限制:

7a60a811e00820d812908cbf3a575c71.png

连续重复内容仅计数(156、157 行):

2665539202941c0de8bbfb6767465ed3.png

五、NuGet 包

https://www.nuget.org/packages/SimpleLogger_dlgcy/

daecc4d3dab878254b59abc55da73e2b.png

支持 .NET Framework 和 .NET Standard(包括 .NET Core),NuGet 包管理器中直接搜索 “简易日志” 即可安装使用:

b31b62c9730e5788019be3646ca98e3b.png

.NET Framework 项目安装时如果提示源中找不到,可以编辑项目文件,添加上

祝大家使用愉快!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值