小编Cra*_*y88的帖子

log4net/c# - 基于级别的不同布局

使用log4net时,有没有办法根据日志消息的级别设置不同的布局?比方说,如果是致命错误,我希望看到所有类型的信息 - 类名,方法名,行号等.但是对于正常,调试和警告,我只想看到消息(我希望,这可以提高性能).

我在C#WinForms中使用log4net.我的要求是在发生致命错误时将所有以前的512条消息记录到文件中,并且我想仅查看致命错误的类名,方法名,行号等,对于所有其他级别,仅查看消息.

c# log4net

8
推荐指数
1
解决办法
3319
查看次数

Log4Net/C# - 禁用默认日志记录

我在C#项目中使用log4net,在生产环境中,我想禁用所有日志记录,但是当发生一些致命错误时,它应该将所有以前的512条消息记录到文件中.我已经成功配置了这个,它是工作正常.当发生致命错误时,它会将消息记录到文件中.

但是当我从Visual Studio运行它时,我可以看到所有日志消息都写入Output窗口,无论它是否是致命的.(当我从Windows资源管理器运行时,我无法看到这些消息 - 我的应用程序是一个WinForm exe,并且没有控制台窗口可以看到输出)

有没有办法禁用此日志记录?我只需要在文件中记录我的日志,当发生一些致命错误时也是如此.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <log4net debug="false">

        <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
            <file value="log.txt" />
            <appendToFile value="true" />
            <rollingStyle value="Size" />
            <maxSizeRollBackups value="10" />
            <maximumFileSize value="1MB" />
            <staticLogFileName value="true" />
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
            </layout>
        </appender>

        <appender name="BufferingForwardingAppender" type="log4net.Appender.BufferingForwardingAppender" >
            <bufferSize value="512" />
            <lossy value="true" />
            <evaluator type="log4net.Core.LevelEvaluator">
                <threshold value="FATAL"/>
            </evaluator>
            <appender-ref ref="RollingFileAppender" />
        </appender> 

        <root>
            <level value="DEBUG" />
            <appender-ref ref="BufferingForwardingAppender" />          
        </root>
    </log4net>
</configuration>
Run Code Online (Sandbox Code Playgroud)

这就是我在Windows窗体的静态初始化程序中配置它的方法.

static Window1() …
Run Code Online (Sandbox Code Playgroud)

c# log4net

7
推荐指数
1
解决办法
7288
查看次数

标签 统计

c# ×2

log4net ×2