使用Websharp Service Locator简化分布式系统开发
2024-07-21 02:21:15
供稿:网友
使用websharp service locator
简化分布式系统开发
什么是websharp service locator
对于多层的应用系统来说,我们通常把它们划分成客户端、应用服务层和数据库。在应用服务层,我们需要考虑至少两个方面的问题:
ü 如何实现业务逻辑
ü 如何向客户端提供服务。
我们可能使用多种技术来实现服务的提供:webservice、.net remoting、甚至ejb等。如此多的实现技术,带来的很大的灵活性,但同时也带来了问题,其中一个就是,有多少种服务端技术,就得有多少种相应的客户端访问技术。甚至,在某些分布式应用系统中,应用逻辑使用不同的技术开发,存在于不同的机器上,有的存在于客户机本机,有的使用.net remoting开发,存在于局域网内,有的使用因特网上的web service,有的时候,我们希望相同的业务逻辑能够支持不同的客户端。
在这种情况下,我们需要一个一致的服务访问编程模型,以统合不同的服务访问模式,简化系统的开发和部署。websharp service locator(以下简称wsl)提供了这样一种能力,开发人员只需要定义服务访问接口,就可以使用一致的方式透明的访问这些服务,而不用理会这些服务之间的不同点。框架会自动生成访问远程服务需要的代理。
websharp是sourceforge上的一个新的开源项目,目标是提供一个.net环境下的轻量级的应用系统框架,它包含了三个主要内容:一个o/r mapping框架,一个aop框架,以及一个service locator。service locator目前还只完成本地程序集定位器、webservice定位器和.net remoting定位器的初步开发,但是,我们已经可以使用它提供的框架功能来为我们的开发提供助力。websharp service locator下面的目标是实现对j2ee的访问。可以从 http://www.sourceforge.net/projects/websharp/ 下载所有源代码。
websharp service locator的主要接口
wsl是一个轻量级的框架,非常易于使用和扩展。如果想使用wsl,那么只有一个类需要打交道:servicelocator,它的定义如下:
public abstract class servicelocator
{
public static object findservice(string servicename,type clientinterface)
}
如果你想用自己的定位器扩展这个框架,那么,只有一个接口需要扩展:iservicelocator。这个接口非常简单,只有一个方法:
public interface iservicelocator
{
object findservice(string servicename,type clientinterface);
}
websharp service locator的配置文件
需要在三个地方配置wsl。
首先,在configsections节中,注册wsl配置文件处理类的的相关信息,配置方法如下:
<configsections>
<section name="websharp.enterprise"
type="websharp.enterprise.enterpriseconfighandler,websharp" />
configsections>
然后,在websharp.enterprise节中,注册不同的服务定位器。如果你自己扩展了这个框架,添加了新的服务定位器,也在这里注册。其中,locator属性的格式是:“类全名,assembly名”。 服务定位器都是singleton的。下面是目前wsl支持的服务定位器的注册的信息:
<websharp.enterprise>
<servicetypes>
<servicetype name="localassembly"
locator="websharp.enterprise.localassemblylocator,websharp" />
<servicetype name="webservice"
locator="websharp.enterprise.webservicelocator,websharp" />
<servicetype name="dotnetremoting"
locator="websharp.enterprise.dotnetremotinglocator,websharp" />
servicetypes>
websharp.enterprise>
最后,在websharp.enterprise下的services节中,注册每个服务。每个service需要的属性取决于不同的locator的实现,但是,name、service-type 和deploy-model是必须的。对于deploy-model,可以有两种属性值:singleton和multiinstance。
下面是一个例子:
<websharp.enterprise>
<servicetypes>
<servicetype name="localassembly"
locator="websharp.enterprise.localassemblylocator,websharp" />
<servicetype name="webservice"
locator="websharp.enterprise.webservicelocator,websharp" />
<servicetype name="dotnetremoting"
locator="websharp.enterprise.dotnetremotinglocator,websharp" />
servicetypes>
<services>
<service name="helloworld" service-type="localassembly" deploy-model="singleton"
type="enterpriseclient.helloworld,enterpriseclient" />
<service name="helloworldwebservice" service-type="webservice"
deploy-model="singleton"
url="http://localhost/webservicetest/hello.asmx"
namespace="http://www.websharp.org/webservices/" />
services>
websharp.enterprise>
注:对于配置文件,在web项目中,可以是web.config文件,对于windows项目,可以自己为项目添加一个app.config配置文件。关于.net项目配置文件的更多内容,请参考msdn的相关文档。
如何使用websharp service locator?
使用wsl,一般的方法是这样的:
1. 定义一个同你需要访问的服务一致的接口(当然,如果你的服务是实现某个接口的,可以直接使用该接口)。接口的方法名和参数必须同服务类的方法名和参数一致。如果你的方法名和服务的方法名不一致,那么,可以使用servicemethodnameattribute来指明服务的方法名。
2. 在配置文件按中注册你需要访问的服务。
3. 调用servicelocator 的findservice方法.
4. 调用接口的方法。.
下面是一些例子,这些例子使用visual studio.net 2003开发,同样可以从sourceforge下载。
localassemblylocator 的hello world例子
按照以下步骤进行:
1. 创建一个名为“enterpriseclient”的windows console 项目,加入websharp.dll的引用。
2. 添加一个类,名为“helloworld” ,然后添加一个名为“gethello”的方法,代码如下:
public class helloworld
{
public string gethello(string hello)
{
return hello;
}
}
3. 添加一个名为 “ihelloworld” 的接口,代码如下:
public interface ihelloworld
{
string gethello(string hello);
[servicemethodname("gethello")]
string gethello2(string hello);
}
4. 填写配置文件
xml version="1.0" encoding="utf-8" ?>
<configuration>
<configsections>
<section name="websharp.enterprise"
type="websharp.enterprise.enterpriseconfighandler,websharp" />
configsections>
<websharp.enterprise>
<servicetypes>
<servicetype name="localassembly"
locator="websharp.enterprise.localassemblylocator,websharp" />
<servicetype name="webservice"
locator="websharp.enterprise.webservicelocator,websharp" />
servicetypes>
<services>
<service name="helloworld" service-type="localassembly"
deploy-model="singleton"
type="enterpriseclient.helloworld,enterpriseclient" />
services>
websharp.enterprise>
configuration>
5. 在main方法中添加如下代码:
public static void main(string[] args)
{
ihelloworld hello= servicelocator.findservice("helloworld",typeof(ihelloworld)) as ihelloworld;
console.writeline(hello.gethello("hello world"));
console.writeline(hello.gethello2("hello again"));
console.readline();
}
6. 运行程序,就能够得到下面的结果:
hello world 的webservicelocator例子
按照以下步骤进行:
1. 新建一个webservice 项目,名为“webservicetest”。
2. 新建一个webservice 类,名为“hello” ,并添加一个“helloworld”方法,代码如下:
[webservice(namespace="http://www.websharp.org/webservices/")]
public class hello : system.web.services.webservice
{
[webmethod]
public string helloworld()
{
return "hello world";
}
}
3. 使用上面我们创建的“enterpriseclient”项目,添加一个接口“ihello” ,代码如下:
public interface ihello
{
string helloworld();
}
4. 填写配置文件
<service name="helloworldwebservice" service-type="webservice" deploy-model="singleton"
url="http://localhost/webservicetest/hello.asmx"
namespace="http://www.websharp.org/webservices/" />
5. 在main方法中添加下面的代码:
public static void main(string[] args)
{
ihello hello1= servicelocator.findservice
("helloworldwebservice",typeof(ihello)) as ihello;
console.writeline(hello1.helloworld());
console.readline();
}
6. 运行程序,能够得到下面的结果:
小结
使用wsl,我们可以使用一致的编程模型访问不同类型的服务,从而简化软件的开发和部署。例如,我们可以在开始的时候,使用本地assembly的方式开发软件,然后,能够很容易的改成使用webservice来发布服务,将软件变成多层应用。我们也可以使用wsl来让相同的服务能够支持不同的客户端,而所有的客户端都使用相同的编程模型。
websharp是一个还处于开发阶段的框架,但是,因为他是开放源代码的,我们可以直接使用他来进行进一步的开发。目前wsl支持的服务还不是很多,实现也还比较简单,但是,他提供了一个很好的框架和构建分布式应用的方案,将来,他将提供越来越多的功能。