完全不使用配置文件构建和使用WCF服务
|
源代码网整理以下只使用代码而不用配置文件的情况不适合IIS为宿主的情况,IIS宿主必须使用配置文件配置WCF的ServiceHost. 源代码网整理以下1、 服务端 源代码网整理以下1.1. 准备Contract和实现Contract的服务 源代码网整理以下很简单的一个Contract(Interface)和实现这个Contract(实现这个接口的类)的服务。 源代码网整理以下这是VS2005中使用add new item,选WCF Service后自动生成的一个模板例子服务代码。 源代码网整理以下
源代码网整理以下1.2. 建立ServiceHost 源代码网整理以下一般使用public ServiceHost(Type serviceType, params Uri[] baseAddresses)构造方法建立ServicesHost. 源代码网整理以下参数: 源代码网整理以下
源代码网整理以下一个ServiceHost内只能驻留一个Service类,但是这个Service类可以实现多个Contract,每个Contract都能通过一个或多个(不同的bind)Endpoint向客户端暴露。 源代码网整理以下进程、应用程序域和ServiceHost 源代码网整理以下Dotnet出现之前,资源的分配是以进程为单位,进程是应用程序的安全边界,进程之间不能直接访问,一个进程的崩溃也不会直接影响到别的进程。 源代码网整理以下但是,进程有个缺点,为了维护进城的安全上下文,耗费的资源很大。 源代码网整理以下后来引入了线程,一个进程中可以包含多个线程,同一进程里的线程共享资源、切换方便,但是线程不具有隔离性,一个线程的崩溃将会影响到其他线程。 源代码网整理以下Dotnet引入了应用程序域,是介于进程和线程之间的逻辑概念,它既有进程的安全隔离性的优点,又有线程轻巧快捷的特性。应用程序域跟进程一样,一个应用程序域不能直接访问另一个应用程序域的资源,一个应用程序域的崩溃也不会影响其他应用程序域。同时应用程序域占用的资源比进程少的多,应用程序直接的切换也很快捷。 源代码网整理以下一个进程中可以包含多个应用程序域,一个应用程序域内有可以包含多个线程。 源代码网整理以下所有的win可执行文件(exe、dll等等)的开头都是一个被称作(Portable Executable)结构,dotnet的可执行文件同样也是用了这个PE头(结构同以前的兼容,只是增加了些内容),下面是dotnet的PE主要包含的信息: 源代码网整理以下运行这个可执行文件要求的最低CLR版本号 源代码网整理以下是否使用了强名称 源代码网整理以下程序的入口地址 源代码网整理以下可执行文件的元数据(metadata) 源代码网整理以下简单的dotnet的exe可执行文件的载入过程: 源代码网整理以下windows程序载入器(os loader)读取exe文件的PE头,获取入口地址,exe入口地址其实是个跳转指令指向mscoree.dll中的_corexemain函数。 源代码网整理以下_corexemain函数实际上是个入口程序,一般被称作shim(填隙物)。由这个入口程序来决定使用哪个类型的CLR(服务器类型或工作站类型),和什么版本的CLR来运行这个exe. 源代码网整理以下确定了使用哪个CLR后,动态载入这个CLR,把控制权交给CLR. 源代码网整理以下 源代码网供稿. |
