1

我正在尝试配置基于 Topshelf 的 Windows 服务以使用 Topshelf.Log4Net 和 log4net 记录到自定义事件日志。如果我在命令行模式下运行应用程序,这很好。当我尝试使用 安装服务时BillsTestService.exe install,我得到:

INFO  Topshelf v3.1.107.0, .NET Framework v4.0.30319.18052
DEBUG Attempting to install 'BillsTestService'
Running a transacted installation.
...
Service BillsTestService has been successfully installed.
Creating EventLog source BillsTestService in log Application...

An exception occurred during the Install phase.
System.ArgumentException: Source BillsTestService already exists on the local computer.
...
   at System.Diagnostics.EventLog.CreateEventSource(EventSourceCreationData sourceData)

我试过EventLog.DeleteEventSource("BillsTestService");在安装之前在 LINQPad 中运行;成功,但后续服务安装仍然失败。

我的 log4net appender 配置是:

<appender name="ErrorEventLogAppender" type="log4net.Appender.EventLogAppender" >
  <threshold value="ERROR" />
  <logName value="MyCompanyServices" />
  <applicationName value="BillsTestService" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%-5level %logger - %message%newline" />
  </layout>
</appender>

我究竟做错了什么?

目的是让多个服务将错误记录到相同的日志名称(具有不同的应用程序名称);日志将由操作创建。

4

2 回答 2

5

部分问题是 Topshelf 在安装时会自动创建一个以服务命名的事件日志源。由于 log4net 附加程序 applicationName 也用作事件日志源,因此它不能是实际的应用程序/服务名称。源在本地计算机上必须是唯一的。我在 log4net 配置中的名称中添加了“Source”后缀。

另一部分是该服务没有创建日志的权限。它可以创建新源,但不能创建新日志。一种方法是在代码中(我使用 LINQPad):

EventLog.CreateEventSource("FOODEBUG", "MyCoSvc");

EventLog mylog = new EventLog("MyCoSvc");
mylog.Source = "FOODEBUG";

mylog.WriteEntry("This is a test.");

EventLog.DeleteEventSource("FOODEBUG");

如果您实际上必须写入日志来创建它,我不肯定;在这花了两天多之后,我宁愿安全。

另请注意,日志名称限制为 8 个字符;您可以更长,但系统仅将前 8 个字符视为重要字符。

没有必要像 Chris Patterson 建议的那样移动 log4net 初始化。简单地包括

configurator.DependsOnEventLog();
configurator.UseLog4Net("MyService.exe.config");

HostFactory.Run委托中就足够了。(我正在使用 Topshelf.Log4Net。)

最后,我有理由确定整个 Windows 事件记录系统是不稳定的。事件查看器的刷新并非在所有情况下都有效,有一次我的应用程序日志条目消失了,我相信我在重新启动后看到了不同的结果。

于 2013-12-20T21:21:43.283 回答
0

将 log4net 初始化移动到服务的 ConstructUsing() 配置委托,而不是指定在不需要实例化服务类的安装/卸载期间使用。

或者,仅在实际服务运行时使用事件日志附加程序,通过在配置文件之外添加附加程序或修改配置以消除事件日志附加程序,除非发生错误或致命事件。

我的猜测是 DEBUG/INFO 级别的事件正在尝试记录到 appender,并且源还不存在。

于 2013-12-19T16:29:50.090 回答