【发布时间】:2012-06-16 10:18:07
【问题描述】:
我已经检查了连接字符串(我从服务器资源管理器中得到它)。
我已经检查了 log4net 配置中的 commandText。
我已经检查了数据库权限(集成安全性很好,并且在 log4net 类之外工作)。
我检查了存储库的已配置属性(已配置,它发现配置文件正常)。
我还检查了配置文件中定义的字段是否与数据库中表的属性(字段大小等)匹配。
有什么想法吗?
当我调试时,它似乎在所有正确的时间使用了所有正确的方法,没有引发异常。
<log4net>
<appender name="ADONetAppender" type="log4net.Appender.ADONetAppender">
<bufferSize value="1" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="" />
<commandText value="INSERT INTO dbo.Log4Net ([Date],[Thread],[Level],[Logger],[Message]) VALUES ('01-01-2001', 'test', 'test', 'test', 'test')"/>
<!--<commandText value="INSERT INTO dbo.Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception],[MachineName],[CultureId],[SourcePage],[Details],[Method]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception, @MachineName, @CultureId, @SourcePage, @Details, @Method)" />-->
<parameter>
<parameterName value="@log_date"/>
<dbType value="DateTime"/>
<layout type="log4net.Layout.RawTimeStampLayout"/>
</parameter>
<parameter>
<parameterName value="@thread"/>
<dbType value="String"/>
<size value="255"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread"/>
</layout>
</parameter>
<parameter>
<parameterName value="@log_level"/>
<dbType value="String"/>
<size value="50"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level"/>
</layout>
</parameter>
...more parameters
<securitycontext type="log4net.Util.WindowsSecurityContext">
<credentials value="Process">
</credentials>
</securitycontext>
</appender>
<appender name="FileAppender" type="log4net.Appender.FileAppender">
<param name="File" value="LogTest.txt"/>
<param name="AppendToFile" value="true"/>
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-2p %c [%x] - %m%n"/>
</layout>
</appender>
<root>
<appender-ref ref="ADONetAppender"/>
<appender-ref ref="FileAppender"/>
</root>
</log4net>
它没有写入任何附加程序。
【问题讨论】:
-
95% 的时间你在配置上搞砸了。请发布您的 log4net 配置。
-
非常感谢您的回复 Jeremy,我将准备将其粘贴到此处(删除 conn 字符串等)。谢谢。
-
添加文件追加器并检查它是否登录文件。如果您可以调试检查记录器上的标志 IsInfoEnabled 等是否为真...
-
感谢 Felice - 我也尝试了文件附加程序并更新了 OP。
标签: c# sql-server database logging log4net