首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使Log4Net在控制台应用程序中写入EventLog?

如何使Log4Net在控制台应用程序中写入EventLog?
EN

Stack Overflow用户
提问于 2016-04-13 20:54:38
回答 2查看 3.4K关注 0票数 2

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

代码语言:javascript
复制
<?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>

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

代码语言:javascript
复制
log4net.Config.XmlConfigurator.Configure();
Logger.log.Info("Launching " + options.Input);
Logger.log.Debug("TestDebugMsg");
Logger.log.Fatal("TestFatalMsg");

这是我的记录器类:

代码语言:javascript
复制
using log4net;

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

根据Apache FAQ的说法,这个问题经常是由于需要作为管理员创建日志。我已经通过New命令手动创建了带有GamePlayTestLog源代码的GamePlayTest。GamePlayTestLog出现在事件日志中,事件日志中的事件为零。但是,这些消息将转到文本文件和控制台。

我怀疑这个问题与源有关,因为我不知道如何设置它。我只是希望使用exe名称作为源可以工作。有一些相关的网页和S/O文章,但都非常过时。我尝试过来自这里的代码。我也尝试了GitHub的例子,但没有成功。我觉得我漏掉了一些显而易见的东西。

我从作为管理员启动的GamePlayTest.exe会话中运行控制台应用程序( PowerShell )。下面是内部log4net日志的内容:

代码语言:javascript
复制
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]

下面是日志文件中的一个示例行:

代码语言:javascript
复制
2016-04-13 17:27:52,098 [1] INFO  GamePlayTest.Logger - Launching C:\Program Files (x86)\Devotion\DevotionWin.exe
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-04-13 22:18:42

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

票数 1
EN

Stack Overflow用户

发布于 2016-04-13 22:26:51

只有创建事件日志需要以管理权限运行。在使用New-EventLog时,确保参数-LogName对应于log4net配置中的'LogName‘param,而-Source参数对应于log4net配置中的’`ApplicationName‘param。

创建日志条目时,应用程序本身不需要登录到windows事件日志的管理权限。在创建事件日志之后,关闭EventViewer并再次打开它,条目应该出现在树视图中的Applications and Services Logs节点下。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36609391

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档