本机跟踪功能不生成输出



我正在研究如何正确使用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" />

相关内容

  • 没有找到相关文章

最新更新