依赖关系在大型应用程序中实现EventSource以进行语义记录

DeC*_*Caf 7 .net etw etw-eventsource

我正在开发一个包含三个Windows服务和几个普通Windows应用程序(.exe)的大型产品.现在我们要转向ETW和语义记录,并使用Microsoft.Diagnostics.Tracing.EventSource.

我在某处读到应用程序的所有逻辑连接部分都应使用相同的事件源.这意味着我们希望为我们的服务提供几乎一个EventSource.但是,如果不在产品中的几乎所有组件中引入依赖关系,我们怎么做呢?

该应用程序目前包含约70个程序集.并且为了能够在EventSource中创建一个log-method(例如接受枚举值),包含事件源的程序集必须引用定义枚举的程序集,这意味着需要将枚举定义从使用它的程序集,或者.exe可能是所有程序集引用的东西.

有没有办法在一个仍然使用相同ETW EventSource的应用程序中从EventSource派生几个类?或者,如果不希望引入一大堆新的依赖项来创建日志类,那么在这样的场景中使用ETW实现语义日志记录的好方法是什么?

Ser*_*kov 0

有以下三种策略:

  1. 创建一个仅包含 EventSource 派生类的程序集,该类为所有应用程序定义事件。将对该程序集的引用添加到所有必需的项目中。为简单起见,您可以将其包装到 nuget 包中。
  2. 创建一个仅包含一个 EventSource 派生类的测试项目。仅将其用于验证目的。将此类复制到所有必需的项目中。这基本上是相同的解决方案,但没有二进制依赖性。
  3. 为每个项目创建新的 EventSource 派生类,但为它们指定相同的 Guid 属性。在这种情况下,您需要确保所有这些事件源对于重叠(具有相同 ID)事件具有相同的声明。在这种情况下,您必须编写一些清单合并工具来生成组合清单。