草庐IT

binary_log_types

全部标签

c# - log4Net 中记录器和根级别的区别?

我刚刚遇到了log4net配置中的两个部分:我可以知道在logger和root标签上指定级别有什么区别吗?它们有什么区别? 最佳答案 root表示应用中的所有日志,logger允许引用某类日志。使用它们,您可以仅为某些日志更改日志配置。查看带有评论的样本:在此示例中,所有日志均为INFO,类型为“File”(或命名为File)的日志为WARN。 关于c#-log4Net中记录器和根级别的区别?,我们在StackOverflow上找到一个类似的问题: https

c# - 3rd 方库引用不同版本的 log4net.dll

我有两个对我的应用程序至关重要的库,它们依赖于不同版本的log4net.dll。当我正在使用的第3方部分被调用时,在我的bin文件夹中尝试这两个dll会出现通常的错误:无法加载文件或程序集“log4net,Version=1.2.10.0,Culture=neutral,PublicKeyToken=1b44e1d426115821”或其依赖项之一。找到的程序集的list定义与程序集引用不匹配。(HRESULT异常:0x80131040)有没有一种方法可以让应用程序同时引用这两个dll?第三方dll是Windsor的IOC容器和Paypal的API,两者都对这个应用程序至关重要。

c# - 串行日志 : Log to different files

我正在将所有类型的事件记录到单个Json文件中,而不管LogLevel。现在我需要将一些自定义性能计数器记录到单独的Json文件中。如何在Serilog中完成此操作。我是否应该创建不同的记录器实例并在我要记录性能计数器的地方使用它?想将其与LibLog一起使用 最佳答案 您可以通过首先确保性能计数器事件标记有特定属性值(LibLog中的OpenMappedContext())或来自特定类型/命名空间来执行此操作。varlog=LogProvider.For()log.Info(...);配置Serilog时,一个sub-logger

c# - 为什么 typeA == typeB 比 type == typeof(Type B) 慢?

我最近一直在优化/对一些代码进行基准测试并遇到了这个方法:publicvoidSomeMethod(TypemessageType){if(messageType==typeof(BroadcastMessage)){//...}elseif(messageType==typeof(DirectMessage)){//...}elseif(messageType==typeof(ClientListRequest)){//...}}这是从其他地方的性能关键循环调用的,所以我很自然地假设所有这些typeof(...)调用都增加了不必要的开销(我知道这是一种微优化)并且可以移动到类中的私有

c# - 简易喷油器 : Registering a type with constructor argument that's based on its parent

我目前正在从我的项目中删除Ninject,并转而使用SimpleInjector,但有一件事我无法正常工作。对于我的日志记录,在注册服务时,我以前能够将参数传递到我的日志记录类中_kernel.Bind().To().WithConstructorArgument("name",x=>x.Request.ParentContext.Request.Service.FullName);我正在寻找一种在SimpleInjector中重新创建它的方法。到目前为止,除了这个,我还有其他所有工作。通过执行以下操作,我可以使日志记录正常工作,尽管没有显示正确的记录器名称:_container.Re

c# - Log4Net 在单独的配置文件中

我需要为一个新项目配置log4net。当我将所有信息保存在App.config文件中时,一切正常。我想把log4net的配置放在一个单独的配置文件中(拿App1.config)这是我的app.config完美运行:我删除了除之外的所有内容从我的app.config元素并将其放入我的app1.config中:在我的Program.cs类中,我用这样的程序集调用配置:[assembly:log4net.Config.XmlConfigurator(ConfigFile="App1.config",Watch=true)]但是当我使用App1.config时,我的文件中没有日志。

c# - 如何在运行时添加 log4net appender?

如何在运行时添加额外的日志附加程序?(所有预先存在的附加程序必须继续工作)我正在尝试这种方式:varlayout=newPatternLayout("%utcdate%-5level-%message%newline");layout.ActivateOptions();_log4netAppender=newFileAppender{Layout=layout,File=logFilePath,};_log4netAppender.ActivateOptions();BasicConfigurator.Configure(_log4netAppender);但它不会向文件写入任何内容

c# - log4net 输出文件但不输出到调试窗口

我正在尝试获取错误的输出以显示在附加的日志文件中以及调试窗口中。日志文件工作正常,但调试窗口中什么都没有显示。首先,这是我的配置然后我在我的代码中调用log4netlog.Debug("Debugerrorlogging",ex);log.Info("Infoerrorlogging",ex);log.Warn("Warnerrorlogging",ex);log.Error("Errorerrorlogging",ex);log.Fatal("Fatalerrorlogging",ex);这在我的日志文件中创建了5个条目,但在我的控制台窗口中没有条目。我还修改了我的web.confi

c# - 如何修复 'T' 是 'type parameter' 但被用作 'variable' 编译错误

我需要检查泛型类型参数T是MyEntity还是它的子类。下面的代码会导致这个编译器错误:'T'isa'typeparameter'butisusedlikea'variable'如何修复?publicclassMyEntity{}staticvoidTest(){//Error34'T'isa'typeparameter'butisusedlikea'variable'if(TisMyEntity){}} 最佳答案 您可以使用IsAssignableFromType上的方法检查是否有一个Type可以分配给另一个。if(typeof(

使用 Json.Net : Error converting value to type 的 C# 枚举反序列化

我正在使用Json.NET序列化/反序列化一些JSONAPI。API响应有一些整数值映射到应用程序中定义的枚举。枚举是这样的:publicenumMyEnum{Type1,Type2,Type3}并且JSONAPI响应具有以下内容:{"Name":"abc","MyEnumValue":"Type1"}有时,API会为我的枚举中未定义的MyEnumValue字段返回一个值,如下所示:{"Name":"abc","MyEnumValue":"Type4"}抛出异常:Errorconvertingvalue"Type4"totype'MyEnum'有没有办法通过分配默认值或其他方法来避免应