Spring.Net记录与log4net的不工作
-
05-09-2019 - |
题
我遇到了麻烦Spring.Net登录,使用log4net的。我是在看到周围的各个方面记录格外感兴趣。我使用一个非常简单的日志配置,类似于的MovieFinder示例应用的:
...
<logger name="Spring">
<level value="DEBUG" /> <!-- Have tried INFO as well, no different -->
<appender-ref ref="SpringAppender"/>
</logger>
<appender name="SpringAppender" type="log4net.Appender.RollingFileAppender">
<file value="..\Log\Spring_Log.txt"/>
<appendToFile value="true"/>
<maximumFileSize value="100MB"/>
<maxSizeRollBackups value="2"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline"/>
</layout>
</appender>
...
在文件“Spring_Log.txt”被创建,但没有被记录到它(即空的文件)。 log4net的是当前登录正确的NHibernate和我们的自定义应用程序日志。我使用Spring.Net v1.2.0.20313和log4net的v1.2.10.0。
有其他人有这个问题,他们能够解决?非常感谢您的帮助,欢呼声。
解决方案
由于埃里希说,你需要配置Common.Logging。 你的log4net的配置文件是好的。下面是我用你的配置文件得到了什么:
2009-05-02 19:08:40,890 DEBUG [10] Spring.Objects.Factory.Support.AbstractObjectDefinitionReader - Loading XML object definitions from config [C:\Documents and Settings\pczapla\My Documents\Visual Studio 2008\Projects\TimeLogger\TimeLogger\bin\Debug\TimeLogger.exe.config#spring/objects]
2009-05-02 19:08:40,905 DEBUG [10] Spring.Objects.Factory.Support.AbstractObjectDefinitionReader - Using the following XmlReader implementation : System.Xml.XsdValidatingReader
2009-05-02 19:08:40,921 DEBUG [10] Spring.Objects.Factory.Xml.DefaultObjectDefinitionDocumentReader - Loading object definitions.
2009-05-02 19:08:40,921 DEBUG [10] Spring.Objects.Factory.Xml.ObjectDefinitionParserHelper - Loading object definitions...
下面是一个快速指导如何配置Common.Logging:
...添加Common.Logging&Common.Logging.Log4Net组件它们是随在lib文件夹(C:\Program Files\Spring.NET 1.2.0\lib\Net\2.0\
)弹簧。
那么下面的配置添加到您的app.config
:
<configuration>
</configSections>
...
<sectionGroup name="common">
<section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging" />
</sectionGroup>
</configSections>
...
<common>
<logging>
<factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4net">
<!-- Common Logging assumes that log4net is initialized -->
<arg key="configType" value="EXTERNAL"/>
<!-- Or it can configure log4net for you
<arg key="configType" value="FILE-WATCH" />
<arg key="configFile" value="path\to\your\log4net.config" />
-->
</factoryAdapter>
</logging>
</common>
</configuration>
这是它。现在,你应该从春天获得调试消息。
其他提示
Spring.NET使用Common.Logging。是否配置Common.Logging登录到log4net的?请参阅 http://netcommon.sourceforge.net/documentation.html 获得的文档
HTH, 埃里希
不隶属于 StackOverflow