Log4Net, 내 로깅에 사용자 정의 필드를 추가하는 방법
log4net.Appender.AdoNetAppender appender를 사용합니다.
내 log4net 테이블은 다음 필드입니다.[Date],[Thread],[Level],[Logger],[Message],[Exception]
log4net 테이블 (예 : SalesId)에 다른 필드를 추가해야하지만 오류 또는 정보 메시지를 기록 할 때 "SalesId"를 기록하려면 XML과 코드에서 어떻게 지정해야합니까?
예 : log.Info("SomeMessage", SalesId)
다음은 log4net xml입니다.
<appender name="SalesDBAppender" type="log4net.Appender.AdoNetAppender">
<bufferSize value="1" />
<connectionType value ="System.Data.SqlClient.SqlConnection" />
<connectionString value="Data Source=..." />
<commandText value="INSERT INTO Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
<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>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
</appender>
1) 명령 텍스트를 수정합니다. INSERT INTO Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception],[MyColumn]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception, @CustomColumn)
2) 사용자 정의 열에 대한 매개 변수 정의를 추가하십시오.
<parameter>
<parameterName value="@CustomColumn"/>
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{CustomColumn}" />
</layout>
</parameter>
3) 그런 다음 log4net의 컨텍스트 중 하나를 사용하여 값을 매개 변수로 전송합니다.
// thread properties...
log4net.LogicalThreadContext.Properties["CustomColumn"] = "Custom value";
log.Info("Message");
// ...or global properties
log4net.GlobalContext.Properties["CustomColumn"] = "Custom value";
Log4Net에서 사용할 수있는 세 가지 유형의 로깅 컨텍스트.
Log4Net.GlobalContext :-이 컨텍스트는 모든 응용 프로그램 스레드 및 도메인에서 공유됩니다. 두 스레드가 GlobalContext에 동일한 속성을 설정하면 하나의 값이 다른 값을 재정의합니다.
Log4Net.ThreadContext :- This context scope limited to calling thread. Here two threads can set same property to different values without overriding to each other.
Log4Net.ThreadLogicalContext :- This context behaves similarly to the ThreadContext. if you're working with a custom thread pool algorithm or hosting the CLR, you may find some use for this one.
Add the following code to your program.cs file:
static void Main( string[] args )
{
log4net.Config.XmlConfigurator.Configure();
log4net.ThreadContext.Properties[ "myContext" ] = "Logging from Main";
Log.Info( "this is an info message" );
Console.ReadLine();
}
2) Add the parameter definition for the custom column:
<log4net>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger (%property{myContext}) [%level]- %message%newline" />
</layout>
</appender>
</log4net>
Here is a working version with some personalized preferences. I added a custom column for storing a generated exception code.
1) Add your custom column(exceptionCode here) to Log4net config:
<commandText value="INSERT INTO Log([Date],[Thread],[Level],[Logger],[Message],[Exception],[ExceptionCode])
VALUES (@log_date, @thread, @log_level, @logger, @message, @exception,@exceptionCode)" />
<parameter>
<parameterName value="@exceptionCode" />
<dbType value="String" />
<size value="11" />
<layout type="Common.Utils.LogHelper.Log4NetExtentedLoggingPatternLayout">
<conversionPattern value="%exceptionCode{Code}" />
</layout>
</parameter>
2) Log4NetExtentedLoggingCustomParameters.cs
namespace Common.Utils.LogHelper
{
public class Log4NetExtentedLoggingCustomParameters
{
public string ExceptionCode { get; set; }
public string Message { get; set; }
public override string ToString()
{
return Message;
}
}
}
3) Log4NetExtentedLoggingPatternConverter.cs
namespace Common.Utils.LogHelper
{
public class Log4NetExtentedLoggingPatternConverter : PatternConverter
{
protected override void Convert(TextWriter writer, object state)
{
if (state == null)
{
writer.Write(SystemInfo.NullText);
return;
}
var loggingEvent = state as LoggingEvent;
var messageObj = loggingEvent.MessageObject as Log4NetExtentedLoggingCustomParameters;
if (messageObj == null)
{
writer.Write(SystemInfo.NullText);
}
else
{
switch (this.Option.ToLower()) //this.Option = "Code"
{
case "code": //config conversionPattern parameter -> %exceptionCode{Code}
writer.Write(messageObj.ExceptionCode);
break;
default:
writer.Write(SystemInfo.NullText);
break;
}
}
}
}
}
4) Log4NetExtentedLoggingPatternLayout.cs
namespace Common.Utils.LogHelper
{
public class Log4NetExtentedLoggingPatternLayout : PatternLayout
{
public Log4NetExtentedLoggingPatternLayout()
{
var customConverter = new log4net.Util.ConverterInfo()
{
Name = "exceptionCode",
Type = typeof(Log4NetExtentedLoggingPatternConverter)
};
AddConverter(customConverter);
}
}
}
5) Logger.cs // Enjoy your logger with new column! :)
namespace Common.Utils.LogHelper
{
public class Logger
{
static ILog Logger = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public static string LogError(string message, Exception exception = null)
{
var logWithErrCode = GetLogWithErrorCode(message);
Logger.Error(logWithErrCode, exception);
return logWithErrCode.ExceptionCode;
}
private static Log4NetExtentedLoggingCustomParameters GetLogWithErrorCode(string message)
{
var logWithErrCode = new Log4NetExtentedLoggingCustomParameters();
logWithErrCode.ExceptionCode = GenerateErrorCode(); //this method is absent for simplicity. Use your own implementation
logWithErrCode.Message = message;
return logWithErrCode;
}
}
}
references:
http://blog.stvjam.es/2014/01/logging-custom-objects-and-fields-with
참고URL : https://stackoverflow.com/questions/12139486/log4net-how-to-add-a-custom-field-to-my-logging
'programing' 카테고리의 다른 글
전략 패턴과 종속성 주입의 차이점은 무엇입니까? (0) | 2020.09.05 |
---|---|
두 개의 int를 나누면 double에 할당 될 때 올바른 값이 생성되지 않는 이유는 무엇입니까? (0) | 2020.09.05 |
Bootstrap에서 토글 버튼을 만드는 방법 (0) | 2020.09.05 |
리소스 u'tokenizers / punkt / english.pickle '을 찾을 수 없습니다. (0) | 2020.09.04 |
요일의 정수 값을 얻는 방법 (0) | 2020.09.04 |