gpt4 book ai didi

c# - 通过跟踪监听器动态更改跟踪级别

转载 作者:太空狗 更新时间:2023-10-29 20:35:00 24 4
gpt4 key购买 nike

我们有一个巨大的 C# 代码库,它使用 .Net 跟踪和自定义跟踪监听器进行日志记录。我正在探索动态更改跟踪级别的选项(从警告到详细等)。我希望有一种方法可以从跟踪监听器更改跟踪级别,并且我可以修改自定义监听器以更改跟踪源上的日志级别。但这似乎不可能。有没有一种简单的方法可以从跟踪监听器中获取跟踪源对象(无需反射..)?我试图避免从 TraceSource 派生来实现动态跟踪级别,因为它会涉及大量代码更改。有什么建议吗?

这是我们进行跟踪的典型方式:

        TraceSource ts = new TraceSource("TestLogSource");
ts.TraceEvent(TraceEventType.Warning, 0, "warning message");
ts.TraceEvent(TraceEventType.Error, 0, "error message");

<system.diagnostics>
<sources>
<source name="TestLogSource" switchName="GlobalSwitch">
<listeners>
<add name="TestLog"/>
</listeners>
</source>
</sources>
<sharedListeners>
<add name="TestLog" initializeData="test.svclog" type="Library.RolloverXmlTraceListener, Library, Version=4.0.0.0, Culture=neutral, PublicKeyToken=1234.."/>
</sharedListeners>
<switches>
<add name="GlobalSwitch" value="Warning" />
</switches>
</system.diagnostics>

最佳答案

不,没有反射就没有办法做到这一点,即使有反射也会很麻烦。

TraceSource 在根据它的 Switch 调用监听器之前进行过滤属性,并且您无法在没有反射的情况下从 TraceListener 获取源 TraceSource 对象,因此您所要求的是不可行的(并且不是故意的)。

然而,您可以在监听器中实现“动态过滤”。

关于c# - 通过跟踪监听器动态更改跟踪级别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7277062/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com