我正在研究如何正确使用System.Diagnostics
tracing functionality,但无法使我的代码正常工作。我已经阅读了关于configuring tracing,creating and initializing trace listeners,app.config的source元素和一些相关的stackoverflow帖子的官方文档。关于TraceSource的msdn doc使我真的很困惑......
我的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,但它是空的。 事件日志为空。 控制台输出为空。
有人可以给我一个暗示吗?
答案 0 :(得分:0)
问题在于,我查看了TraceEventType和TraceLevel枚举,以便在switch
中设置app.config
的值。
此属性的正确枚举是SourceLevels标记。
我更改了switch
的值。以下解决方案现在正在运行(如果我想跟踪每个事件):
<add name="ApplicationTraceSwitch" value="-1" />
或
<add name="ApplicationTraceSwitch" value="ALL" />