WCF 自托管

1.关于宿主(host)

我们一般创建的是以IIS为宿主的,所以我们平常在VS2008中创建的项目,如下图所示,都是IIS托管的。关于IIS托管,上一篇文章已经说得很清楚了。

 

但是,WCF还有另一种托管方式,称为自托管(Self-Hosting)。

说得深奥些,就是Client和Service共用一个进程。说得通俗些,就是把Client项目和Service项目合二为一,比如说这个Demo:

C:\Users\baoj\Documents\Visual Studio 2008\Projects\WCFSolution。

Demo中一共3个文件,Contract.cs和App.config组成了Service,前者包括了契约及其实现,后者包括了Service的Endpoint,请下载上面的代码并参考相应文件。

而Program.cs中则是一个Client,我们看一下这个宿主是怎样实现的:

class Program {
static void Main(string[] args)
{
using (ServiceHost host = new ServiceHost(typeof(Service)))
{
host.Open();

Console.WriteLine("The Service is ready.");
Console.ReadKey(true);

host.Close();
}
}
}
 

这是宿主的最普遍实现。

我们发现,自托管没有svc文件,可见,svc只是为IIS托管而准备的。如果哪天你看到一个没有svc的WCF Service,不要惊讶,不过是一个自托管罢了。

 

此外,由于把Client和Service放在一起,所以只需要配置Service的Endpoint就可以了。就是说,只有一个配置文件。

但是,在自托管中,把契约(contract)和Client写在一起,是很乱的——瞧人家IIS托管,丁是丁卯是卯,Service和Client完全是分开的。于是,VS2008为我们提供了WCF Service Library这个项目模板,来解决这个问题:

image

于是我们创建这样的一个项目,我们发现,项目中只包括契约和配置文件,如下图所示:

image

接下来就灵活了,我们可以添加一个Console控制台程序ConsoleApplication1,然后添加对WcfServiceLibrary2的引用(注意是项目引用,而不是Service引用),参考下面的示例:

C:\Users\baoj\Documents\Visual Studio 2008\Projects\WcfServiceLibrary2C:\Users\baoj\Documents\Visual Studio 2008\Projects\WcfServiceLibrary2

需要注意的是,我们要把WcfServiceLibrary2中的App.config转移到ConsoleApplication1项目中,不需要说原因了吧~~

切记,转移的意思是是cut,而不是copy。要确保WcfServiceLibrary2中没有这个配置文件,不然就会报错,说已经占用这个地址了。

原贴地址: http://blog.csdn.net/JspAndAsp/archive/2009/10/23/4721531.aspx
posted @ 2009-11-02 16:28  wenw  阅读(627)  评论(0编辑  收藏  举报