我有一个应用程序,它将其跟踪源配置如下:
var traceSource = new TraceSource("MyTraceSource");
traceSource.Switch = new SourceSwitch("MyTraceSwitch") { **Level = SourceLevels.Information** };
var traceListener = new TextWriterTraceListener(logFilePath);
traceListener.TraceOutputOptions = TraceOptions.DateTime;
traceSource.Listeners.Clear();
traceSource.Listeners.Add(traceListener);
Trace.AutoFlush = true;应用程序始终使用此跟踪源来跟踪事件。请注意,SourceLevels.Information是在跟踪开关中硬编码的。现在,我需要将跟踪开关级别更改为Verbose。可以通过app.config文件来完成吗?我尝试了许多xml-configs,但都失败了。注意:我不能只更改app.config的源代码。
发布于 2020-11-20 02:32:43
这是一个问题,在原始问题(vkrzv的帖子)中,听众被删除了:
traceSource.Listeners.Clear();这导致侦听器被添加到app.config (在Glenn Ferries奇妙的解决方案中)。我很喜欢。谢谢。)将被删除。
所以这里有一个完整的解决方案。c:\temp文件夹中有两个日志文件: logcode.txt和logappconfig.txt
代码:
var traceSource = new TraceSource("MyTraceSource");
var traceListener = new TextWriterTraceListener(@"c:\temp\logcode.txt");
traceListener.TraceOutputOptions = TraceOptions.DateTime;
//traceSource.Listeners.Clear(); //we do not want to delete the listener
traceSource.Listeners.Add(traceListener);
Trace.AutoFlush = true;App.Config:
<system.diagnostics>
<sources>
<source name="MyTraceSource" switchValue="Information">
<listeners>
<add name="file" initializeData="c:\temp\logappconfig.txt" traceOutputOptions="DateTime" type="System.Diagnostics.TextWriterTraceListener, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
</listeners>
</source>
</sources>
</system.diagnostics>https://stackoverflow.com/questions/14891089
复制相似问题