我正在研究如何正确使用System.Diagnostics
跟踪功能,但无法让我的代码工作。我已经阅读了关于配置跟踪、创建和初始化跟踪侦听器、app.config的source元素和一些相关的stackoverflow帖子的官方文档。关于TraceSource的msdn文档让我很困惑…
我的app.config
包含以下部分:
<system.diagnostics>
<sources>
<source name="ApplicationTraceSource" switchName="ApplicationTraceSwitch" switchType="System.Diagnostics.SourceSwitch">
<listeners>
<add name="EventLogListener" type="System.Diagnostics.EventLogTraceListener" initializeData="PDS" />
<add name="TextLogListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="PDS.log" />
<add name="ConsoleLogListener" type="System.Diagnostics.ConsoleTraceListener" />
<remove name="Default" />
</listeners>
</source>
<source name="DatabaseActivitySource" switchName="DatabaseActivityTraceSwitch" switchType="System.Diagnostics.SourceSwitch">
<listeners>
<add name="QueryTextLogListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="Queries.log" />
<remove name="Default" />
</listeners>
</source>
</sources>
<switches>
<!--Set value to 0 to turn of database activity log.-->
<add name="DatabaseActivityTraceSwitch" value="1" />
<!--Set value to 0 to turn of application log. 1 for errors. 2 for errors und warnings. 3 for more detailed error information. 4 for verbose trace information.-->
<add name="ApplicationTraceSwitch" value="4" />
</switches>
</system.diagnostics>
我的代码在我的Program.cs
是简单的,因为它可以得到:
if (EventLog.SourceExists("PDS") == false)
{
EventLog.CreateEventSource("PDS", "EventLogListener");
}
TraceSource applicationTraceSource = new TraceSource("ApplicationTraceSource");
applicationTraceSource.TraceInformation("i am information");
applicationTraceSource.TraceEvent(TraceEventType.Error, 1, "i am error event");
applicationTraceSource.TraceEvent(TraceEventType.Warning, 2, "i am warning event");
applicationTraceSource.TraceEvent(TraceEventType.Information, 3, "i am information event");
applicationTraceSource.TraceEvent(TraceEventType.Verbose, 4, " am verbose event");
applicationTraceSource.TraceData(TraceEventType.Error, 5, "i am error data");
applicationTraceSource.TraceData(TraceEventType.Warning, 6, "i am warning data");
applicationTraceSource.TraceData(TraceEventType.Information, 7, "i am information data");
applicationTraceSource.TraceData(TraceEventType.Verbose, 8, " am verbose data");
applicationTraceSource.Flush();
正在创建文件PDS.log,但它是空的。事件日志为空。
控制台输出为空。谁能给我一点提示吗?问题是我查看了TraceEventType和TraceLevel enum,以便在app.config
中设置switch
的值。
正确的enum是SourceLevels标志。
我改变了我的switch
的值。下面的解决方案现在正在工作(如果我想跟踪每个事件):
<add name="ApplicationTraceSwitch" value="-1" />
或
<add name="ApplicationTraceSwitch" value="ALL" />