在Windows Azure中实现和调试一个WCF服务(下)

原创
云计算
为了把在Windows Azure中运行的,使用强大的WCF框架的服务暴露出来,Windows Azure提供了一个WCF角色。无论在哪个框架和平台上构建复杂的,具有高度可扩展性的系统,通过它们的功能进行逻辑分组,针对那些分组来抽象代码,并且分别执行它们,都是一种简单而高效的扩展性策略。

本文接《在Windows Azure中实现和调试一个WCF服务(上)》和《在Windows Azure中实现和调试一个WCF服务(中)

开启诊断

对于我们来说,和诊断有关的大多数工作都已经完成了。但是一定要记住,我们必须要把“sharedListener”添加到“AzureLocalStorage”中。要完成这个工作,只需在“WCF Web Role”的“Web.Config”文件中交换一下被注释掉的“system.diagnostics”节点就可以了,就是这么简单。

除此之外,你还必须把下面这行代码添加到“WebRole.cs”文件中:

DiagnosticMonitor.Start(CloudStorageAccount.DevelopmentStorageAccount, diagnosticConfig);

在使用SDK 1.3把日志迁移到BlobStorage的过程中,我遇到了一个问题。这个问题和作为SVCLog被创建的文件上的可用的权限有关。针对这个问题,有两种解决方案。首先,你可以模仿RobinDotNet(具体可以参考:http://robindotnet.wordpress.com/2011/02/16/azure-toolssdk-1-3-and-iis-logging/ ——我会在以后的文章中讲述具体应该怎么做的)的做法,或者,你也可以在“ServiceDefinition.csdef”中彻底地删除<Sites>节点,这意味着它将不再作为一个完整的IIS来运行。我选择了***种方法,在本文中我只是简单地总结了一下,关于我是如何让它正常工作的,以后我会单独写一篇文章来说明的。现在,如果你无法解决这个SDK 1.3中的已知问题,你可以通过浏览它们的文件路径(使用Development Emulator)直接访问这些文件,或者你也可以使用远程桌面来访问云中的日志。

如果你对立即可以使用的WCF的跟踪日志比较好奇,你可以打开附属的项目,看看它是如何为你工作的——你可以把注意力放在“FixDiagFolderAccess.ps1”这个powershell脚本上。它为这个文件夹创建了一些访问控制表,更重要的是,它会为这个文件创建一个NULL或者完全为空的占位符(我们***会重写这个文件)。

它可以给你提供SVCLog的定义,其中包括了绑定和异常的所有细节。在这里,你可以找到“DivideByZeroException”,然后开始诊断这个问题。

这个文件首先会出现在硬盘上:

片刻之后(注意,在这篇博文中,这个时间没有什么暗示!),Windows Azure Diagnostics系统会把这个文件迁移到blob storage的WAD-TraceFiles容器中。

在此之后,这个日志可以被下载,用来检查错误。在这个例子中,我们可以向下滚动,直到找到和被0除有关的细节,然后我们会发现有一个红色高亮的行显示发生了一个异常。要想查看更多的细节,我们可以从服务端获取这个错误真正的堆栈跟踪信息。

这篇博文的源代码可以从如下地址下载:

http://assets.bareweb.eu/wp-content/uploads/2011/03/WCFBasic.zip

本文接《在Windows Azure中实现和调试一个WCF服务(上)》和《在Windows Azure中实现和调试一个WCF服务(中)

原文名:Implementing and Debugging a WCF Service in Windows Azure 作者:Andy

【本文乃51CTO精选译文,转载请标明出处!】
 

【编辑推荐】 

  1. 微软公布云计算平台Azure收费模式细节
  2. 云计算意在长远,微软云计算服务Windows Azure已经启用
  3. 技术透析:Windows Azure Platform框架与组成
  4. 微软Windows Azure Platform技术解析
  5. 走近微软云:SQL Server到Azure数据同步
  6. 当微软Azure遭遇亚马逊EC2:五大关键区别
  7. Windows Azure云计算平台新增五大功能
  8. 云计算前途光明 Azure用户数突破31000
  9. 如何把应用程序部署到Windows Azure中

 

责任编辑:王勇 来源: 来源:51CTO
相关推荐

2011-03-15 16:07:33

Windows AzuWCF

2011-03-15 15:43:39

Windows AzuWCF

2011-03-22 10:03:55

Windows AzuSilverlight

2010-11-25 10:05:22

Visual StudSilverlightWCF

2011-03-22 09:45:56

Windows AzuSilverlight

2011-03-24 13:02:35

WCF服务角色Azure

2011-03-10 10:45:47

Azure“Hello Worl

2009-06-25 11:18:20

Silverlight

2020-12-16 14:29:40

终端开发shell

2022-05-22 13:55:30

Go 语言

2011-03-15 19:45:27

Windows Azu

2011-03-14 15:14:10

AzureFacebook营销式应用程序

2021-01-04 09:12:31

集合变量

2011-03-14 15:10:10

AzureFacebook

2010-06-02 19:48:23

搭建SVN服务器

2013-05-24 08:56:46

Windows Azu微软云计算平台Windows Ser

2009-12-21 14:58:57

WCF用户密码认证

2013-03-27 09:55:17

微软Windows AzuHadoop

2009-03-30 15:52:24

Windows Emb

2012-06-06 09:52:07

Windows Azu存储安全
点赞
收藏

51CTO技术栈公众号