c# - 如何让 Log4Net 在控制台应用程序中写入 EventLog?

标签 c# logging windows-10 log4net event-log

我正在编写一个控制台应用程序,并希望将日志消息发送到 Windows 事件日志(在我的 Windows 10 笔记本电脑上)。我似乎无法将消息发送到事件日志。但是,我能够让 log4net 写入文本文件并写入控制台。这是我的 app.config 文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net"/>
  </configSections>

  <log4net>

    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
      <param name="File" value="game-playtest-log-file.txt" />
      <param name="AppendToFile" value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="10MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%date [%thread] %-5level %logger - %message%newline" />
      </layout>
    </appender>

    <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender" >
      <param name="LogName" value="GamePlayTestLog" />
      <param name="ApplicationName" value="GamePlayTest" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
      </layout>
    </appender>

    <appender name="colored-console" type="log4net.Appender.ColoredConsoleAppender">
      <mapping>
        <level value="INFO" />
        <foreColor value="White, HighIntensity" />
        <backColor value="Green" />
      </mapping>
      <mapping>
        <level value="DEBUG" />
        <foreColor value="White, HighIntensity" />
        <backColor value="Blue" />
      </mapping>
      <mapping>
        <level value="WARN" />
        <foreColor value="Yellow, HighIntensity" />
        <backColor value="Purple" />
      </mapping>
      <mapping>
        <level value="ERROR" />
        <foreColor value="Yellow, HighIntensity" />
        <backColor value="Red" />
      </mapping>

      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date --- %message%newline%newline"/>
      </layout>
    </appender>

    <root>
      <appender-ref ref="LogFileAppender"/>
      <appender-ref ref="EventLogAppender"/>
      <appender-ref ref="colored-console" />
      <priority value="DEBUG" />
      <level value="ALL"/>
    </root>

  </log4net>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>
</configuration>

这是我正在测试的日志代码:

log4net.Config.XmlConfigurator.Configure();
Logger.log.Info("Launching " + options.Input);
Logger.log.Debug("TestDebugMsg");
Logger.log.Fatal("TestFatalMsg");

这是我的记录器类:

using log4net;

namespace GamePlayTest
{
    public static class Logger
    {
        public static readonly ILog log = LogManager.GetLogger(typeof(Logger));
    }
}

根据Apache FAQ ,这个问题经常是由于需要以管理员身份创建日志造成的。我已通过 New-EventLog 命令使用 GamePlayTest 源手动创建 GamePlayTestLog。 GamePlayTestLog 显示在事件日志中,其中事件数为零。但是,这些消息将发送到文本文件和控制台。

我怀疑这个问题与源有关,因为我不知道如何设置它。我只是希望使用 exe 名称作为源能够工作。有一些相关的网页和S/O文章,但都非常过时了。我已经尝试过 here 中的代码。我也尝试过 GitHub 上的示例,但没有成功。我觉得我错过了一些明显的东西。

我一直在以管理员身份启动的 PowerShell session 中运行控制台应用程序 (GamePlayTest.exe)。以下是内部 log4net 日志的内容:

log4net: log4net assembly [log4net, Version=1.2.15.0, Culture=neutral, PublicKeyToken=**********]. Loaded from [C:\Users\fores\git\game-playtest-tool\GamePlayTest\bin\x64\Release\log4net.dll]. (.NET Runtime [4.0.30319.42000] on Microsoft Windows NT 6.2.9200.0)
log4net: defaultRepositoryType [log4net.Repository.Hierarchy.Hierarchy]
log4net: Creating repository for assembly [GamePlayTest, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null]
log4net: Assembly [GamePlayTest, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null] Loaded From [C:\Users\fores\git\game-playtest-tool\GamePlayTest\bin\x64\Release\GamePlayTest.exe]
log4net: Assembly [GamePlayTest, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null] does not have a RepositoryAttribute specified.
log4net: Assembly [GamePlayTest, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null] using repository [log4net-default-repository] and repository type [log4net.Repository.Hierarchy.Hierarchy]
log4net: Creating repository [log4net-default-repository] using type [log4net.Repository.Hierarchy.Hierarchy]
log4net: configuring repository [log4net-default-repository] using .config file section
log4net: Application config file is [C:\Users\fores\git\game-playtest-tool\GamePlayTest\bin\x64\Release\GamePlayTest.exe.Config]
log4net: Configuring Repository [log4net-default-repository]
log4net: Configuration update mode [Merge].
log4net: Loading Appender [LogFileAppender] type: [log4net.Appender.RollingFileAppender]
log4net: Setting Property [File] to String value [game-playtest-log-file.txt]
log4net: Setting Property [AppendToFile] to Boolean value [True]
log4net: Setting Property [RollingStyle] to RollingMode value [Size]
log4net: Setting Property [MaxSizeRollBackups] to Int32 value [10]
log4net: Setting Property [MaximumFileSize] to String value [10MB]
log4net: Setting Property [StaticLogFileName] to Boolean value [True]
log4net: Converter [message] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Setting Property [ConversionPattern] to String value [%date [%thread] %-5level %logger [%property{NDC}] - %message%newline]
log4net: Converter [date] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [ [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [thread] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [] ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [level] Option [] Format [min=5,max=2147483647,leftAlign=True]
log4net: Converter [literal] Option [ ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [logger] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [ [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [property] Option [NDC] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [] - ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [message] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Setting Property [Layout] to object [log4net.Layout.PatternLayout]
log4net: Searched for existing files in [C:\Users\fores\git\game-playtest-tool\GamePlayTest\bin\x64\Release]
log4net: curSizeRollBackups starts at [0]
log4net: Opening file for writing [C:\Users\fores\git\game-playtest-tool\GamePlayTest\bin\x64\Release\game-playtest-log-file.txt] append [True]
log4net: Created Appender [LogFileAppender]
log4net: Adding appender named [LogFileAppender] to logger [root].
log4net: Loading Appender [EventLogAppender] type: [log4net.Appender.EventLogAppender]
log4net: Setting Property [LogName] to String value [GamePlayTestLog]
log4net: Setting Property [ApplicationName] to String value [GamePlayTest]
log4net: Converter [message] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Setting Property [ConversionPattern] to String value [%date [%thread] %-5level %logger [%property{NDC}] - %message%newline]
log4net: Converter [date] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [ [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [thread] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [] ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [level] Option [] Format [min=5,max=2147483647,leftAlign=True]
log4net: Converter [literal] Option [ ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [logger] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [ [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [property] Option [NDC] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [] - ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [message] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Setting Property [Layout] to object [log4net.Layout.PatternLayout]
log4net: Source [GamePlayTest] is registered to log []
log4net: Created Appender [EventLogAppender]
log4net: Adding appender named [EventLogAppender] to logger [root].
log4net: Loading Appender [colored-console] type: [log4net.Appender.ColoredConsoleAppender]
log4net: Setting Property [Level] to Level value [INFO]
log4net: Setting Property [ForeColor] to Colors value [White, HighIntensity]
log4net: Setting Property [BackColor] to Colors value [Green]
log4net: Setting Collection Property [AddMapping] to object [log4net.Appender.ColoredConsoleAppender+LevelColors]
log4net: Setting Property [Level] to Level value [DEBUG]
log4net: Setting Property [ForeColor] to Colors value [White, HighIntensity]
log4net: Setting Property [BackColor] to Colors value [Blue]
log4net: Setting Collection Property [AddMapping] to object [log4net.Appender.ColoredConsoleAppender+LevelColors]
log4net: Setting Property [Level] to Level value [WARN]
log4net: Setting Property [ForeColor] to Colors value [Yellow, HighIntensity]
log4net: Setting Property [BackColor] to Colors value [Purple]
log4net: Setting Collection Property [AddMapping] to object [log4net.Appender.ColoredConsoleAppender+LevelColors]
log4net: Setting Property [Level] to Level value [ERROR]
log4net: Setting Property [ForeColor] to Colors value [Yellow, HighIntensity]
log4net: Setting Property [BackColor] to Colors value [Red]
log4net: Setting Collection Property [AddMapping] to object [log4net.Appender.ColoredConsoleAppender+LevelColors]
log4net: Converter [message] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Setting Property [ConversionPattern] to String value [%date --- %message%newline%newline]
log4net: Converter [date] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [literal] Option [ --- ] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [message] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Converter [newline] Option [] Format [min=-1,max=2147483647,leftAlign=False]
log4net: Setting Property [Layout] to object [log4net.Layout.PatternLayout]
log4net: Created Appender [colored-console]
log4net: Adding appender named [colored-console] to logger [root].
log4net: Logger [root] Level string is [DEBUG].
log4net: Logger [root] level set to [name="DEBUG",value=30000].
log4net: Logger [root] Level string is [ALL].
log4net: Logger [root] level set to [name="ALL",value=-2147483648].
log4net: Hierarchy Threshold []
log4net: Shutdown called on Hierarchy [log4net-default-repository]

以下是日志文件中的示例行:

2016-04-13 17:27:52,098 [1] INFO  GamePlayTest.Logger - Launching C:\Program Files (x86)\Devotion\DevotionWin.exe

最佳答案

使用自定义事件日志时,您必须重新启动事件日志服务才能使其正确显示。

关于c# - 如何让 Log4Net 在控制台应用程序中写入 EventLog?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36609391/

相关文章:

c# - 使用具有不同类型详细信息的主从 View

android - 为什么我不应该在 android 中使用 System.out.println()

c - 使用 Meson 在 Windows 上构建并运行 GTK 应用程序

visual-studio-2013 - 是否可以将 Windows 10 WDK 与 Visual Studio 2013 集成?

c# - 在上传的文件上添加日期戳

c# - 在 DataGridView 上托管自定义控件,这些控件从 DataTable 填充数据

c# - 如何正确更新我的图表值? (实时)

JAVA SimpleFormatter,无法设置正则表达式

ssl - 减少 Wildfly 日志中的 javax.net.ssl 噪音

docker - 即使不运行容器,启动适用于 Windows 的 Docker 也会占用大量内存 如何防止呢?