本机跟踪功能不会产生输出

时间:2016-09-15 08:22:52

标签: c# .net app-config tracing system.diagnostics

我正在研究如何正确使用System.Diagnostics tracing functionality,但无法使我的代码正常工作。我已经阅读了关于configuring tracingcreating 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,但它是空的。 事件日志为空。 控制台输出为空。

有人可以给我一个暗示吗?

1 个答案:

答案 0 :(得分:0)

问题在于,我查看了TraceEventTypeTraceLevel枚举,以便在switch中设置app.config的值。

此属性的正确枚举SourceLevels标记。

我更改了switch的值。以下解决方案现在正在运行(如果我想跟踪每个事件):

<add name="ApplicationTraceSwitch" value="-1" />

<add name="ApplicationTraceSwitch" value="ALL" />