Log4같은 로거에 대해 두 개의 다른 수준에서 두 개의 다른 추가기에 대한 Net 로깅
Log4net 로깅이 활성화된 두 개의 서로 다른 asp.net 응용 프로그램이 있습니다.둘 다 동일한 버전의 Log4Net 1.2.10.0을 사용합니다.
다음을 추가했습니다.log4net.Appender.AdoNetAppender
로거를 두 개 모두에 기록하고 루트 로거에 대한 정보 수준을 여기에 기록하려고 하지만 파일 appender에 대한 루트 로거에 대한 오류 수준에도 기록하려고 합니다.구성은 다음과 같습니다.
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender" >
<file value="..\logs\app.debug.log" />
<encoding value="utf-8" />
<staticLogFileName value="true" />
<datePattern value=".yyyyMMdd.'log'" />
<rollingStyle value="Composite" />
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<maximumFileSize value="1MB" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%3thread] %-5level %property{log4net:HostName} [%property{Revision}] %logger %message%n" />
</layout>
</appender>
<!--
use [DB]
GO
CREATE TABLE [dbo].[Log] (
[Id] [int] IDENTITY (1, 1) NOT NULL,
[Date] [datetime] NOT NULL,
[Application][varchar] (255) NOT NULL,
[Thread] [varchar] (255) NOT NULL,
[Level] [varchar] (50) NOT NULL,
[Logger] [varchar] (255) NOT NULL,
[Server][varchar](255) NOT NULL,
[Revision][varchar](50) NOT NULL,
[Message] [varchar] (4000) NOT NULL,
[Exception] [varchar] (2000) NULL
)
-->
<appender name="dbLogAppender" type="log4net.Appender.AdoNetAppender" xdt:Transform="InsertBefore(/log4net/root)">
<bufferSize value="100" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="data source=sqlserver;initial catalog=DB;integrated security=false;persist security info=True;User ID=USER;Password=PASSWORD" />
<commandText value="INSERT INTO Log ([Date],[Application],[Thread],[Level],[Logger],[Server],[Revision],[Message],[Exception]) VALUES (@log_date,'WebApp1', @thread, @log_level, @logger, @server, @revision, @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="@server" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{log4net:HostName}"/>
</layout>
</parameter>
<parameter>
<parameterName value="@revision" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{Revision}"/>
</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>
<root>
<level value="Error"/>
<appender-ref ref="filelogAppender"/>
</root>
<root>
<level value="Info"/>
<appender-ref ref="dbLogAppender"/>
</root>
</log4net>
문제는 한 응용프로그램의 경우 DB에 항목이 표시되지만 다른 응용프로그램의 경우에는 표시되지 않는다는 것입니다.
Revision
이라GlobalContext
우리가 설정한 재산Application_Start()
두 응용 프로그램 모두에서.두 구성 간의 유일한 차이점은 하드코딩된 값이 다르다는 것입니다.Application
.
이런 루트 로거 두 개 주세요.이것이 우리가 한 애플리케이션에서 보고 있는 문제의 원인이 될 수 있습니까?
설정할 수 있어야 합니다.threshold
각 appender의 속성을 개별적으로 지정하고 동일한 루트에 포함합니다.
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender">
<threshold value="Error" />
</appender>
<appender name="dblogAppender" type="log4net.Appender.AdoNetAppender">
<threshold value="Info" />
</appender>
<root>
<appender-ref ref="filelogAppender" />
<appender-ref ref="dblogAppender" />
</root>
다음을 지정할 수 있습니다.LevelRangeFilter
각 추가자에 대해 서로 다른 수준에서 기록하도록 루트의 각 추가자를 정의합니다.
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender" >
<!--File Details/Layout Options-->
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="INFO"/>
</filter>
</appender>
<appender name="dbLogAppender" type="log4net.Appender.AdoNetAppender">
<!--SQL Options-->
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ERROR"/>
</filter>
</appender>
<root>
<level value="INFO"/>
<appender-ref ref="filelogAppender" /> <!--Prints info, warn, error, or fatal logs. -->
<appender-ref ref="dbLogAppender" /> <!--Prints only error or fatal logs. -->
</root>
두명<root>
요소는 허용되지 않습니다.
설명서에서:
root Optional element, maximum of one allowed. Defines the configuration of the root logger.
그러나 루트 로거를 사용한 다음 네임스페이스로 지정된 별도의 로거를 사용할 수 있습니다.
<root>
<level value="Error"/>
<appender-ref ref="filelogAppender"/>
</root>
<logger name="MyCompany.MyApp.Namespace">
<level value="Info"/>
<appender-ref ref="dbLogAppender"/>
</logger>
평가자를 사용하기만 하면 모든 첨가제에 임계값을 지정할 필요가 없습니다.
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender">
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR" />
</evaluator>
</appender>
언급URL : https://stackoverflow.com/questions/21186378/log4net-logging-of-two-different-levels-to-two-different-appenders-for-the-same
'code' 카테고리의 다른 글
gitsvn을 사용하여 원격 지점 체크아웃 (0) | 2023.07.02 |
---|---|
SpringBoot의 요청 매핑이 작동하지 않음 (0) | 2023.07.02 |
Mongoid / Mongodb 및 내장된 문서 쿼리 (0) | 2023.07.02 |
데이터베이스 동의어는 언제 사용해야 합니까? (0) | 2023.07.02 |
현재 COM 객체를 사용하는 올바른 방법은 무엇입니까? (0) | 2023.07.02 |