gpt4 book ai didi

nhibernate - log4net - 将 NHibernate 保留在我的应用程序日志文件之外并放入它自己的文件中

转载 作者:行者123 更新时间:2023-12-04 23:27:23 27 4
gpt4 key购买 nike

我已经成功地封锁了我自己的常规和错误日志文件。

我已将 NHibernate 添加到组合中,因为我想记录它生成的 sql 语句以帮助调试 - 但记录到它自己的文件中。

使用我下面的当前配置,NH 输出最终出现在我的通用日志文件 (CommunicationsAppender) 以及它自己的文件中(它是重复的)。如何保持 CommunicationsAppender 的输出?

<log4net> 
<appender name="NHibernateAppender" type="log4net.Appender.RollingFileAppender">
<file value="c:\logs\NHibernate.log"/>
<appendToFile value="true"/>
<maximumFileSize value="1000KB"/>
<maxSizeRollBackups value="10"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %logger %level - %message%newline"/>
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="DEBUG" />
<levelMax value="FATAL" />
</filter>
<filter type="log4net.Filter.LoggerMatchFilter">
<loggerToMatch value="NHibernate.SQL" />
<acceptOnMatch value="true" />
</filter>
<filter type="log4net.Filter.DenyAllFilter" />
</appender>
<appender name="CommunicationsAppender" type="log4net.Appender.RollingFileAppender">
<file value="C:\Logs\Communications Service.log"/>
<appendToFile value="true"/>
<maximumFileSize value="10000KB"/>
<maxSizeRollBackups value="10"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %logger - %message%newline"/>
</layout>

<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="DEBUG" />
<levelMax value="WARN" />
</filter>
<filter type="log4net.Filter.LoggerMatchFilter">
<loggerToMatch value="CommunicationsLogger" />
<acceptOnMatch value="true" />
</filter>
<filter type="log4net.Filter.DenyAllFilter" />
</appender>
<appender name="CommunicationsErrorAppender" type="log4net.Appender.RollingFileAppender">
<file value="C:\Logs\Communications Service Errors.log"/>
<appendToFile value="true"/>
<maximumFileSize value="10000KB"/>
<maxSizeRollBackups value="10"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %logger - %message%newline"/>
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ERROR" />
<levelMax value="FATAL" />
</filter>
<filter type="log4net.Filter.LoggerMatchFilter">
<loggerToMatch value="CommunicationsLogger" />
<acceptOnMatch value="true" />
</filter>
</appender>

<root>
<!-- Value of priority may be ALL, DEBUG, INFO, WARN, ERROR, FATAL, OFF -->
<priority value="ALL"/>
<!--<appender-ref ref="LogToFile"/>-->
<appender-ref ref="CommunicationsAppender" />
<appender-ref ref="CommunicationsErrorAppender" />
<appender-ref ref="NHibernateAppender" />
</root>
<logger name="NHibernate.SQL">
<level value="DEBUG"/>
<appender-ref ref="NHibernateAppender"/>
</logger>
<logger name="NHibernate">
<level value="OFF" />
</logger>
</log4net>

最佳答案

从根目录中删除 NHibernate appender 并添加 additivity="false"到你的 nhibernate appender。

<root>
<!-- Value of priority may be ALL, DEBUG, INFO, WARN, ERROR, FATAL, OFF -->
<priority value="ALL"/>
<!--<appender-ref ref="LogToFile"/>-->
<appender-ref ref="CommunicationsAppender" />
<appender-ref ref="CommunicationsErrorAppender" />
</root>

<logger name="NHibernate.SQL" additivity="false">

关于nhibernate - log4net - 将 NHibernate 保留在我的应用程序日志文件之外并放入它自己的文件中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10533794/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com