.Net 6 Nacos日志控制台疯狂发输出+Log4Net日志过滤

我们的项目配置了Log4Net 作为日志输出工具,在引入Nacos后,控制台和日志里疯狂输出nacos心跳日志和其他相关信息,导致自己记录的信息被淹没了,找了很多解决办法:

1、提高nacos日志级别,然后再屏蔽相应级别的日志:在我没有找到怎么修改nacos日志级别的方法,希望路过的大佬能指点一下。

2、继续百度,想在log4Net.Config里添加配置,进行过滤:在config文件中加了如下配置,不知道是我配置写的有问题,还是其原因,并没有起作用:

复制代码
<appender name="TraceLogAppender" type="log4net.Appender.RollingFileAppender">
		<param name="File" value=".\\logs\\" />
		<param name="AppendToFile" value="true" />
		<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
		<param name="MaxSizeRollBackups" value="100" />
		<param name="MaximumFileSize" value="5000KB" />
		<param name="StaticLogFileName" value="false" />
		<param name="DatePattern" value="yyyyMMdd&quot;-Info.txt&quot;" />
		<param name="CountDirection" value="1" />
		<param name="RollingStyle" value="Composite" />
		<filter type="log4net.Filter.LevelRangeFilter">
			<levelMin value="INFO" />
			<levelMax value="INFO" />
		</filter>
		<filter type="log4net.Filter.StringMatchFilter">
			<param name="StringToMatch" value="System.Net.Http.HttpClient.NacosClient.*" />
			<param name="StringToMatch" value="Chitic.Module.Nacos.*" />
		</filter>
		<!--<layout type="log4net.Layout.PatternLayout">
			<param name="ConversionPattern" value="%d [%t] %-5p %c [%x]  - %m%n %n %n" />
		</layout>-->
	</appender>

3、最后,突然想到在添加日志时加过滤选项:在program.cs 中修改日志的配置,添加过滤项config.AddFilter(),上代码

复制代码
//注入日志
builder.Services.AddLogging(config =>
{
    config.AddLog4Net();
//添加如下信息,强制过滤Nacos相关日志
    config.AddFilter((ms,filter) =>
    {
        //return true;
        if (ms.Contains("Nacos") || filter == LogLevel.Trace /*|| filter == LogLevel.Information */)
            return false;
        else
            return true;
    });
});

虽然这个方法有些暴力,但是完美的解决了我的问题,在此记录一些,有同样困扰的码友,希望本文能提供帮助或思路。

相关推荐
张人玉2 小时前
C# 通讯关键类的API
开发语言·c#
William_cl10 小时前
C# MVC 修复DataTable时间排序以及中英文系统的时间筛选问题
开发语言·c#·mvc
c#上位机11 小时前
wpf之RelativeSource用法总结
c#·wpf
Dm_dotnet11 小时前
WPF应用最小化到系统托盘
c#
*长铗归来*13 小时前
ASP.NET Core Web API 中控制器操作的返回类型及Swagger
后端·c#·asp.net·.netcore
R-G-B16 小时前
【06】C#入门到精通——C# 多个 .cs文件项目 同一项目下添加多个 .cs文件
开发语言·c#·c# 多个 .cs文件项目
EdisonZhou16 小时前
多Agent协作入门:基于A2A协议的Agent通信(中)
aigc·agent·.net core
懒人Ethan1 天前
解决一个C# 在Framework 4.5反序列化的问题
java·前端·c#
mysolisoft1 天前
Avalonia+ReactiveUI实现记录自动更新
c#·avalonia·reactiveui·sourcegenerator
心疼你的一切1 天前
使用Unity引擎开发Rokid主机应用的模型交互操作
游戏·ui·unity·c#·游戏引擎·交互