代码中的 WCF 跟踪不遵循 MessageLogging 设置

2023-12-03

我需要在我的应用程序中使用 WCF 跟踪,但需要尽可能通过代码进行控制。

建议我在 app.config 文件中安装以下部分:

<configuration>
  <system.serviceModel>
    <diagnostics>
      <messageLogging
        maxMessagesToLog="100"
        logEntireMessage="true"
        logMessagesAtServiceLevel="true"
        logMalformedMessages="true"
        logMessagesAtTransportLevel="true">
      </messageLogging>
    </diagnostics>
  </system.serviceModel>  
  <system.diagnostics>
    <sources>
      <source name="System.ServiceModel" >
        <listeners>
          <add type="System.Diagnostics.DefaultTraceListener" name="dummy"/>
        </listeners>
      </source>
    </sources>
  </system.diagnostics>
</configuration>

然后可以使用以下代码来根据需要运行跟踪:

BindingFlags privateMember = BindingFlags.NonPublic | BindingFlags.Instance;
BindingFlags privateStaticMember = privateMember | BindingFlags.Static;

Type type = Type.GetType("System.ServiceModel.DiagnosticUtility, System.ServiceModel, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089");
MethodInfo[] mi = type.GetMethods(privateStaticMember);

// invoke InitializeTracing   
object diagnosticTrace = mi.FirstOrDefault(e => e.Name == "InitializeTracing").Invoke(null, null);
if (diagnosticTrace != null)
{
    // get TraceSource   
    Type type2 = Type.GetType("System.ServiceModel.Diagnostics.DiagnosticTrace, SMDiagnostics, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089");
    PropertyInfo pi = type2.GetProperty("TraceSource", privateMember);
    TraceSource traceSource = pi.GetValue(diagnosticTrace, null) as TraceSource;

    // clear all listeners in the trace source   
    traceSource.Listeners.Clear();

    // add listener to trace source   
    XmlWriterTraceListener listener = new XmlWriterTraceListener("mylogfile".svclog");
    listener.TraceOutputOptions = TraceOptions.Timestamp | TraceOptions.Callstack;
    traceSource.Attributes["propagateActivity"] = "true";
    traceSource.Switch.ShouldTrace(TraceEventType.Verbose | TraceEventType.Start);
    traceSource.Listeners.Add(listener);

    // enable tracing   
    type.GetProperty("Level", privateStaticMember).SetValue(null, SourceLevels.All, null);

    Trace.AutoFlush = true;

这在某种程度上工作正常,主要问题是 app.config 文件的 system.servicemodel 部分中的消息记录设置被忽略。

有什么办法可以解决这个问题吗?


我无法评论您的所有代码,因为我之前没有以这种方式使用 System.Diagnostics(以编程方式配置 WCF 通信跟踪),但如果您对此行的意图是:

traceSource.Switch.ShouldTrace(TraceEventType.Verbose | TraceEventType.Start);

是设置您想要的跟踪级别,我认为您应该使用 Switch.Level 属性。 ShouldTrace 用于询问给定的 TraceSource 是否would跟踪,给定输入标志。

traceSource.Switch.Level = SourceLevels.Verbose | SourceLevels.ActivityTracing; 

请注意,根据这个链接,可以配置明显合理的设置,但活动 ID 可能无法正确传播。仔细阅读。它可能适用也可能不适用于您的情况。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

代码中的 WCF 跟踪不遵循 MessageLogging 设置 的相关文章

随机推荐