首页 > 解决方案 > 卸载没有清单文件的事件源(ETW)?

问题描述

在不使用清单的情况下卸载/删除以前安装的事件源的最佳方法是什么?

例如。如果我有类似的东西:


    [EventSource(Name = "Corporation-Module-X")]
    public sealed class XEventSource : EventSource
    {
        //...
    }

对于安装事件源,我使用的是wevtutil {im | 安装清单}

如果我有清单,卸载很容易。但是我可以在没有清单文件的情况下卸载事件源吗?


我将尝试阐明我如何使用事件源以及我为什么要删除它。

使用 wevtutil 安装事件源后,事件源作为事件跟踪提供程序可见。因此,我可以在性能监视器中创建新的数据收集器集,并在其中添加我的事件源(连同一些性能计数器)。它看起来像这样:

新收集器集中的 ETW EventSource

可能发生的情况是事件源被重命名或删除。例如,在使用 wevtutil 重命名和安装之后。


    [EventSource(Name = "Corporation-Module-Y")]
    public sealed class XEventSource : EventSource
    {
        //...
    }

事件跟踪提供程序中仍然存在旧的:

ETW 新事件源

我想要的是查询所有以Corporation*开头的已安装事件提供程序,并在安装新事件提供程序之前将其删除。

在此处输入图像描述

谢谢!

标签: c#etweventsourceetw-eventsource

解决方案


无需卸载任何东西,因为如果您使用EventSource ,则未注册清单。清单被发送ManifestData 事件

在此处输入图像描述

到侦听器工具(Perfview,Windows Performance Toolkit),以便他们可以解释记录的数据。

注册提供程序后,您可以转储清单并再次使用 wevtutil 将其删除。


推荐阅读