Entendo por que o log4net usa app.config
arquivos para configurar o log - para que você possa alterar facilmente como as informações são registradas sem precisar recompilar seu código. Mas, no meu caso, não quero compactar um app.config
arquivo com o meu executável. E não desejo modificar minha configuração de log.
Existe uma maneira de configurar o código de logon em vez de usar o app.config
?
Aqui está o meu arquivo de configuração simples:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="Logs\EventLog.txt" />
<appendToFile value="false" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="5" />
<maximumFileSize value="1GB" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
</layout>
</appender>
<appender name="MemoryAppender" type="log4net.Appender.MemoryAppender">
</appender>
<root>
<level value="Info" />
<appender-ref ref="RollingLogFileAppender" />
<appender-ref ref="MemoryAppender" />
</root>
</log4net>
</configuration>
EDITAR:
Para ser completamente claro: é meu objetivo não ter um arquivo XML. Nem como um recurso incorporado que eu me transformo em um fluxo. Meu objetivo era definir o criador de logs completamente programaticamente. Só estou curioso para saber se é possível e, em caso afirmativo, onde posso encontrar um exemplo da sintaxe.
BasicConfigurator.Configure(hierarchy);
vez de apenas definirhierarchy.Configured = true;
.log4net.Util.LogLog.InternalDebugging = true;
antes de qualquer outra chamada do log4net, execute no depurador e inspecione a saída. O log4net lhe dirá onde as coisas dão errado.Você também pode escapar completamente do XML, escrevi uma amostra com configuração programática mínima aqui .
Em poucas palavras, aqui está o que você precisa
fonte
Sim, você pode configurar o log4net chamando:
Veja a documentação do log4net .
fonte
Como alternativa, você pode criar um atributo personalizado que herda de log4net.Config.ConfiguratorAttribute e codificar sua configuração lá:
Em seguida, adicione o seguinte a um arquivo .cs:
fonte
Para aqueles que não desejam adicionar appender ao registrador raiz, mas ao registrador atual / outro:
fonte
A resposta aceita funciona depois que eu encontrei duas advertências:
roller.File
propriedade, ele começou a funcionar.nuget_log4net.fsx:
fonte