Azure开发者任务之六:使用WCF Service Web Role

在本文中,咱们将会在local development fabric上建立一个WCF服务角色,而后在一个控制台应用程序中使用它。浏览器

WCF服务角色可让咱们建立一个WCF服务,而且把它托管在Windows Azure中。在本文中,咱们将会建立一个WCF服务角色,把它托管在local development fabric上,而后在一个控制台应用程序中使用它。在下一篇文章中,咱们将会把这个WCF服务迁移到Azure门户中。测试

首先spa

1,建立一个新项目code

2,导航到“Cloud”标签orm

3,建立Windows Azure项目资源

4,在给出的选项中选择WCF服务角色rpc

若是你看一下解决方案资源管理器,你会发现这个WCF服务角色项目的结构和文件与正常建立的WCF服务应用程序彻底相同。它包含:get

1,IService1.cs(服务契约)string

2,Service1.svc.cs(服务定义)it

3,Web.config(EndPoint的配置)

咱们能够按照咱们的需求来修改这些文件,这和咱们平时在一个WCF服务应用程序中作的事情没有什么两样。

让咱们来修改服务契约:

IService1.svc

using System.ServiceModel;
 
namespace WCFServiceWebRole1

{   

[ServiceContract]

public interface IService1

{
 
        [OperationContract]

string GetData(int value);
     
    } 

}

而后,修改服务定义:

Service1.svc.cs

namespace WCFServiceWebRole1

{

public class Service1 : IService1

{

public string GetData(int value)

{

return string.Format("You entered: {0}", value);

}
 
    }

}

在Web.Config中保留默认的配置。

确保你已经把Windows Azure项目设置成启动项目了,而后运行这个应用程序。在浏览器中,你会获得以下错误信息:

忽略这个错误信息,而后把一个URL添加到“Service1.svc”中,这个URL应该是http://127.0.0.1:81/Service1.svc。“Service1.svc”是服务定义的名字。添加之后,你会在浏览器中获得一般的WCF服务消息

要在一个控制台客户端中测试这个WCF服务角色,须要:

1,建立一个控制台应用程序项目

2,使用指定的URL(http://127.0.0.1:81/Service1.svc)来添加服务引用

如今,咱们编写一个正常的服务调用:

Program.cs

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using ConsoleApplication14.ServiceReference1;

namespace ConsoleApplication14

{

class Program

{

static void Main(string[] args)

{

Service1Client proxy = new Service1Client();

var result = proxy.GetData(99);

Console.WriteLine(result);

Console.ReadKey(true);

}

}

}

如今,当你运行这个应用程序的时候,你也许会获得下面这个异常:

要解决上面这个异常,咱们必需要编辑“App.Config”文件。咱们须要修改这个配置文件:

“127.0.0.1”表明“localhost”。也许这个控制台应用程序不能解析“127.0.0.1”,因此,咱们把它改为“localhost”:

如今,运行这个应用程序,咱们会获得以下输出:

这里,咱们须要注意的一个行为是,有时,在把“127.0.0.1”改为“localhost”之后,你可能仍是会获得那个超时异常。在我之后的文章中,我会深刻研究一下这个意料以外的行为。

原文名:Windows Azure for Developers Task 8: Working with WCF Service Web Role 做者: Dhananjay Kumar

相关文章
相关标签/搜索