WCF跟踪调试具体代码详细剖析

开发 开发工具
WCF跟踪调试的工具主要有两种,一种是SvcConfigEditor,另一种则为SvcTraceViewer。他们都是由微软提供的一种辅助工具。

WCF中,有一中比较有用的操作技术,教唆WCF跟踪调试,它可以为我们带来非常大的帮助。在WCF中提供了两个工具可以进行WCF跟踪调试,我主要是用来跟踪传输的xml是否符合我定义的schema。#t#

这两个WCF跟踪调试的工具是:

工具路径:C:\Program Files\Microsoft SDKs\Windows\v6.0A\bin

SvcConfigEditor:微软提供的用来辅助编辑WCF配置文件的工具

SvcTraceViewer:微软提供的用来查看WCF的Trace Log的工具。

跟踪配置

启动SvcConfigEditor.exe, 用这个程序打开wcf service host程序的web.config 或者app.config,除了WMI Provider,其它的全部Enable, 在log file选择svclog文件的保存路径, 然后save, 如果config文件在源码管理器,记得先签出,才能保存。

 

也可以手动配置添加如下内容,不使用上面的WCF跟踪调试工具

< configuration>节理添加如下内容

 

 

  1. < system.diagnostics>   
  2. < sources>   
  3. < source name="System.ServiceModel.MessageLogging" 
    switchValue="Warning, ActivityTracing">   
  4. < listeners>   
  5. < add type="System.Diagnostics.DefaultTraceListener" name="Default">   
  6. < filter type="" />   
  7. < /add>   
  8. < add name="ServiceModelMessageLoggingListener">   
  9. < filter type="" />   
  10. < /add>   
  11. < /listeners>   
  12. < /source>   
  13. < source name="System.ServiceModel" 
    switchValue="Warning, ActivityTracing"   
  14. propagateActivity="true">   
  15. < listeners>   
  16. < add type="System.Diagnostics.DefaultTraceListener" name="Default">   
  17. < filter type="" />   
  18. < /add>   
  19. < add name="ServiceModelTraceListener">   
  20. < filter type="" />   
  21. < /add>   
  22. < /listeners>   
  23. < /source>   
  24. < /sources>   
  25. < sharedListeners>   
  26. < add initializeData="E:\Web_messages.svclog"   
  27. type="System.Diagnostics.XmlWriterTraceListener, 
    System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
       
  28. name="ServiceModelMessageLoggingListener" traceOutputOptions="Timestamp">   
  29. < filter type="" />   
  30. < /add>   
  31. < add initializeData="E:\Web_tracelog.svclog"   
  32. type="System.Diagnostics.XmlWriterTraceListener, System, 
    Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
       
  33. name="ServiceModelTraceListener" traceOutputOptions="Timestamp">   
  34. < filter type="" />   
  35. < /add>   
  36. < /sharedListeners>   
  37. < trace autoflush="true" />   
  38. < /system.diagnostics> 

 

< System.ServiceMode>节里会添加

 

 

  1. < diagnostics>   
  2. < messageLogging logEntireMessage="true" logMalformedMessages="true"   
  3. logMessagesAtTransportLevel="true" />   
  4. < /diagnostics> 

查看

启动SvcTraceViewer, 打开刚才的svclog文件,调用wcf service,然后就可以看到消息的记录。以上就是我们为大家介绍的WCF跟踪调试的相关方法。

责任编辑:曹凯 来源: 博客园
相关推荐

2009-12-07 18:43:29

WCF框架

2010-02-23 16:07:39

2010-03-02 09:39:11

保护WCF服务

2010-02-25 13:40:17

WCF禁用安全配置

2010-02-26 10:24:43

Python源代码

2010-02-24 16:17:09

WCF获取客户端IP

2010-03-02 16:15:59

WCF控制事务

2010-02-23 09:34:15

WCF重载

2010-02-22 16:09:33

WCF宿主

2010-02-22 10:01:11

WCF消息处理

2010-02-22 15:27:05

WCF数据契约

2009-11-09 11:15:06

WCF消息队列

2009-06-25 16:03:29

Netbeans调试

2010-03-02 13:43:01

WCF事务演示

2010-02-22 16:26:47

WCF传输数据

2009-11-06 09:14:14

WCF可靠性

2009-12-08 17:56:16

WCF配置

2010-03-02 16:28:11

WCF发布订阅

2009-12-08 10:21:17

WCF地址

2010-02-25 14:26:48

WCF特点
点赞
收藏

51CTO技术栈公众号