Click here to Skip to main content
Click here to Skip to main content

Simple steps to enable tracing in WCF

By , 13 Jul 2012
 

Tracing mechanism in Windows Communication Foundation is based on the classes that resides in System.Diagnostic namespace.Important classes are Trace, TraceSource and TraceListener.

Following are the steps to enable tracing in WCF:

1. Configuring WCF to emit tracing information/Define Trace Source, we have the following options:

  • System.ServiceModel 
  • System.ServiceModel.MessageLogging 
  • System.ServiceModel.IdentityModel
  • System.ServiceModel.Activation 
  • System.Runtime.Serialization 
  • System.IO.Log
  • Cardspace

In configuration file, we will define a source to enable this configuration as follows:

       <source name="System.ServiceModel.MessageLogging">

2. Setting Tracing Level, we have the following available options, we need to set this tracing level to available options other than default "Off": 

  • Off
  • Critical
  • Error
  • Warning
  • Information
  • Verbose
  • ActivityTracing
  • All

In configuration file, we can choose above values for switchValue attribute as follows:

<source name="System.ServiceModel.MessageLogging"
                               switchValue="Information">

3. Configuring a trace listener

For configuring a trace listener, we will add following to config file.

      <listeners>
        <add name="messages"
                 type="System.Diagnostics.XmlWriterTraceListener"
                 initializeData="d:\logs\messages.svclog" />
      </listeners>

4. Enabling message logging.     

      <system.serviceModel>
         <diagnostics>
            <messageLogging 
                    logEntireMessage="true" 
                    logMalformedMessages="false"
                    logMessagesAtServiceLevel="true" 
                    logMessagesAtTransportLevel="false"
                    maxMessagesToLog="3000"
                    maxSizeOfMessageToLog="2000"/>
         </diagnostics>
       </system.serviceModel>
  • logEntireMessage: By default, only the message header is logged but if we set it to true, entire message including message header as well as body will be logged.
  • logMalformedMessages: this option log messages those are rejected by WCF stack at any stage are known as malformed messages.
  • logMessagesAtServiceLevel: messages those are about to enter or leave user.
  • logMessagesAtTransportLevel: messages those are about to encode or decode.
  • maxMessagesToLog: maximum quota for messages. Default value is 10000.
  • maxSizeOfMessageToLog: message size in bytes.

Finally, putting all this together, configuration file will appear like this. 

 <system.diagnostics> 
   <sources>
      <source name="System.ServiceModel.MessageLogging">
        <listeners>
          <add name="messagelistener"
               type="System.Diagnostics.XmlWriterTraceListener" 
                      initializeData="d:\logs\myMessages.svclog"></add>
        </listeners>
      </source>
    </sources>
  </system.diagnostics> 
  <system.serviceModel>       
      <diagnostics>
        <messageLogging logEntireMessage="true"
                        logMessagesAtServiceLevel="false"
                        logMessagesAtTransportLevel="false"
                        logMalformedMessages="true"
                        maxMessagesToLog="5000"
                        maxSizeOfMessageToLog="2000">         
        </messageLogging>
      </diagnostics>
  </system.serviceModel>

Note: In this case, information will be buffered and not published to file automatically, So, we can set the autoflush property of the trace under sources as follows:

<trace autoflush ="true" />

Other Top WCF Tutorials

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Imran Abdul Ghani
Software Developer (Senior)
United Arab Emirates United Arab Emirates
Member
Imran Abdul Ghani has more than 10 years of experience in designing/developing enterprise level applications. He is Microsoft Certified Solution Developer for .NET(MCSD.NET) since 2005. You can reach his blogging at WCF Tutorials, Web Development.

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
QuestionEnabling WCF tracing and MessageLoggingmemberAshish Ramteke20 May '13 - 20:58 
QuestionMore options for loggingmemberkatrash17 Jul '12 - 6:33 
SuggestionFormatting...mvpSandeep Mewara12 Jul '12 - 22:54 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web04 | 2.6.130516.1 | Last Updated 13 Jul 2012
Article Copyright 2012 by Imran Abdul Ghani
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid