The combination of what I am assuming is the small things that stop my application from database logging, as I expect.
- The text team works. Both teams
INSERTboth EXECwork, and the data is entered into the database - If I uncomment a parameter
ExecutionTime, it stops working. , I know that someone was working at some point, but I can’t understand why uncommenting a parameter, let alone adding it, makes Appender fail silently. - An error was detected in debug. Listed and updated below with added accuracy and scale.
I'm trying to enable internal debugging and doesn't seem to want to work. Problem detected. Moved the configuration sections to the right place (not in log4net).- If I switch commandType to
StoredProcedure, it stops working even if the text version is working - Another problem. Trying different things, but they were out of luck.
SQL:
DROP TABLE [LOG];
GO
CREATE TABLE [dbo].[LOG] (
[Id] [int] IDENTITY(1,1) NOT NULL
,[Origin] [varchar](55) null
,[LogDate] [datetime] NOT NULL
,[Thread] [varchar](32) NOT NULL
,[Context] [varchar](10) NOT NULL
,[Level] [varchar](10) NOT NULL
,[Logger] [varchar](255) NOT NULL
,[Message] [varchar](4000) Not NULL
,[MethodName] [varchar](200) NULL
,[Parameters] [varchar](4000) NULL
,[Exception] [varchar](4000) NULL
,[ExecutionTime] [decimal](14, 4) NULL
)
GO
DROP PROCEDURE InsertLog
GO
CREATE PROCEDURE [dbo].[InsertLog]
@LogDate DateTime
,@Thread varchar(32)
,@Context varchar(10)
,@Level varchar(10)
,@Logger varchar(255)
,@Message varchar(4000)
,@MethodName varchar(200) = null
,@Parameters varchar(4000) = null
,@Exception varchar(4000) = null
,@ExecutionTime decimal(14,4) = null
AS
BEGIN
SET NOCOUNT ON;
INSERT INTO [dbo].[LOG] ([Origin],[LogDate],[Thread],[Level],[Logger],[Message],[MethodName],[Parameters],[Exception],[Context])
VALUES ('InsertLog',@LogDate, @Thread, @Level, @Logger, @Message, @MethodName, @Parameters, @Exception, @Context)
END
GO
App.config
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
...
</configSections>
<connectionStrings>...</connectionStrings>
<applicationSettings>...</applicationSettings>
<log4net configSource="Log4Net.config" />
<appSettings>
<add key="log4net.Internal.Debug" value="true" />
</appSettings>
<system.diagnostics>
<trace autoflush="true">
<listeners>
<add name="textWriterTraceListener" type="System.Diagnostics.TextWriterTraceListener" initializeData=".\log4net.log" />
</listeners>
</trace>
</system.diagnostics>
</configuration>
log4net.config
<?xml version="1.0" encoding="utf-8" ?>
<log4net>
<root>
<level value="ALL" />
<appender-ref ref="ColoredConsoleAppender"/>
<appender-ref ref="ADONetAppender" />
<appender-ref ref="OutputDebugStringAppender" />
<appender-ref ref="TraceAppender" />
</root>
<appender name="ADONetAppender" type="log4net.Appender.ADONetAppender">
<threshold value="ALL"/>
<bufferSize value="1" />
<lossy value="false"/>
<param name="UseTransactions" value="False" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
<connectionString value="..." />
<commandText value="
exec InsertLog @log_date,@thread,@Context,@Level,@Logger,@Message,@MethodName,@Parameters,@Exception;"
/>
<parameter name="LogDate">
<parameterName value="@log_date"/>
<dbType value="DateTime"/>
<layout type="log4net.Layout.RawTimeStampLayout"/>
</parameter>
...
<parameter name="ExecutionTime">
<parameterName value="@ExecutionTime"/>
<dbType value="Decimal"/>
<precision value="14"/>
<scale value="4"/>
<layout type="log4net.Layout.PatternLayout" value="%property{execution_time}" />
</parameter>
</appender>
<appender name="OutputDebugStringAppender" type="log4net.Appender.OutputDebugStringAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level %logger (%file:%line) - %message%newline" />
</layout>
</appender>
<appender name="TraceAppender" type="log4net.Appender.TraceAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level - %message%newline" />
</layout>
</appender>
</log4net>
Update 1
Now that I have a Trace job, she complains that the DB team needs to explicitly set the accuracy and scale. You do not know how to do this, since none of the examples that I have seen has this set
log4net: ERROR [AdoNetAppender] ErrorCode: GenericFailure. [exec InsertLog @Log_date, @ @, @Level, @Logger, @, @MethodName, @, @Exception; ] System.InvalidOperationException: SqlCommand.Prepare "" . System.Data.SqlClient.SqlParameter.Prepare(SqlCommand cmd) System.Data.SqlClient.SqlCommand.Prepare() at log4net.Appender.AdoNetAppender.InitializeDatabaseCommand()
2
Precision/Scale . :
log4net: ERROR [AdoNetAppender] ErrorCode: GenericFailure. DoAppend System.FormatException: . --- > System.FormatException: .