回顾.NET Remoting分布式开发

简介:

记得在下第一次接触.NET Remoting分布式开发是在2003年,那时候是Framework1.0初次亮相之时,Remoting分布式开发是Framework1.0其中一个亮点。经过多年的发展,在2005年,WCF随着Framework2.0首先亮相。WCF是结合Remoting,Web服务,TCP/IP套接字,MSMQ信息,P2P,WSE等多方通讯的混合体。随着WCF的出现是否意昧着Remoting即将没落,答案是否定的。因为Remoting有其独到之处,在通讯效率,信息交换,安全性等多方面都有其特点,所以在企业内部系统的信息化交换层的开发当中,很多时候会使用Remoting进行开发,在下面几章为大家回顾一下Remoting的开发。

一、基础概念

Remoting是采用分布式进行编程的一种技术,主要用于管理跨应用程序域的同步和异步RPC 会话。在默认情况下,Remoting可从使用 HTTP 或 TCP 协议进行信息通讯,并使用 XML 编码的 SOAP 或二进制消息格式进行数据交换。.NET Remoting 提供了非常灵活和可扩展的编程框架,并且可以管理对象的状态。Remoting跟Web服务不同,它并不依赖于IIS,用户可以自己开发(Development)并部署(Dispose)宿主服务器,只需要服务器支持Framework。

二、Remoting的特点

Remoting可以灵活的定义其所基于的协议,比如http,tcp等。在使用TCP/IP的时候,Remoting能发挥更高的效率,其性能接近于DCOM。

Remoting一般需要通过一个应用程序或是Windows服务来承载,也可以使用iis部署。

Remoting必须要在一个支持Framework的开发环境下进行开发,无论客户端跟服务器端都必须支持Framework。

Remoting 支持许多状态管理选项,并且可能与来自同一个用户的多个调用相关或不相关,这取决于您选择的对象生命周期架构。

三、利用Remoting实现分布式开发的优点

  • 容错性

容错性是指一个系统在出现故障时,系统应当能及时恢复。利用Remoting实现分布式应用开发可以建立容错软件系统,当某个功能发生错误时,不会影响整体系统的工作。使系统能够及时维护及更新。

  • 可扩展性


  • 易于管理

一个大型计算机管理系统是非常复杂的,可能涉及的是异地机器之间的代码调节。利用Remoting实现分布式开发,可以把核心的功能代码移植到中央服务器,把页面层,UI层等功能于客户端实现。这样系统的性能调节,代码升级都可以在中央服务器里综合实现,而忽略对客户端的影响。

四、Remoting体系结构

下面详细介绍一下Remoting的体系结构,如下图。

在客户发送请求时可以通过Activator.GetObject()和 Activator.CreateInstance()返回一个透明代理对象。实际上透明代理就像一个远程对象,它执行远程对象的所有公共方法,这些方法调用真实对象的Invoke()方法,传送包含方法调用的消息。

当消息进入Channel通道后,就会经过接收器处理。接收器包含格式接收器、通道接收器和传输接收器,其中格式接收器和传输接收器是必要的。首先格式接收器会使用SoapFormatter或BinaryFormatter的方式对传输的对象进行序列化,如果用户设定了通道接收器,系统将会对其进行对应处理,最后把信息送到传输接收器,对应设定TCP或HTTP传输方式加入传输接收器头。当信息发送到服务器,服务器将会根据传输接收器头对信息进行处理,然后在格式化接收器中对信息进行反序列化,最后通过真实代理处理远程对象。至于“通道接收器”的处理方式,将在后几章为大家进一步地介绍。

五、简单实例

说了这么多,下面就以一个简单的例子说明一下Remoting的开发过程吧。

首先建立一个Model.dll,注意因为对象要进行序列化转化,必须对其加上Serializable特性!

 
  1. 代码 
  2.  
  3. using System; 
  4. using System.Collections.Generic; 
  5. using System.Linq; 
  6. using System.Text; 
  7.  
  8. namespace Model 
  9.     [Serializable] 
  10.     public class Person 
  11.     { 
  12.         public int ID 
  13.         { 
  14.             get
  15.             set
  16.         } 
  17.  
  18.         public String Name 
  19.         { 
  20.             get
  21.             set
  22.         } 
  23.  
  24.         public int Age 
  25.         { 
  26.             get
  27.             set
  28.         } 
  29.     } 

然后建立一个可远程调用的对象,注意远程对象必须继承MarshalByRefObject

 
  1. 代码 
  2.  
  3. using System; 
  4. using System.Collections.Generic; 
  5. using System.Linq; 
  6. using System.Text; 
  7. using System.Runtime.Serialization.Formatters.Binary; 
  8. using System.IO; 
  9. using Model; 
  10.  
  11. namespace Manager 
  12.     //类必须继承了MarshalByRefObject,才能进行远程调用 
  13.     public class PersonManager:MarshalByRefObject 
  14.     { 
  15.         public List<Person> GetList() 
  16.         { 
  17.             List<Person> personList = new List<Person>(); 
  18.             FileStream stream = new FileStream("DataSource.sour", FileMode.Open, FileAccess.Read);  //在服务器文件里面获取虚拟数据 
  19.             BinaryFormatter formatter = new BinaryFormatter(); 
  20.             personList=(List<Person>)formatter.Deserialize(stream);  //对虚拟数据进行反序列化获取集合 
  21.             return personList; 
  22.         } 
  23.     } 

在一个应用程序中加载服务器端,服务器端的配置有两种试,一是直接写在代码里面。首先建立服务传送方式,可以选择用TcpServerChannel,也可使用HttpChannel,前者有着更高的效率。然后在ChannelService注册此传输通道,最后通过RemotingConfiguration的RegisterWellKnownServiceType方法注册远程对象。

注意WellKonwnObjectMode可选择为SingleTon或者SingleCall,前者使用单体模式,每个客户端进行访问都会使用同一个远程对象。后者会为每个请求建立一个远程对象。在这个例子里面我们使用SingleTon单体模式。

 
  1. 代码 
  2.  
  3. using System.Runtime.Remoting; 
  4. using System.Runtime.Remoting.Channels; 
  5. using System.Runtime.Remoting.Channels.Tcp; 
  6. using Model; 
  7. using Manager; 
  8.  
  9. namespace Server 
  10.     class Program 
  11.     { 
  12.         static void Main(string[] args) 
  13.         { 
  14.             //建立服务传输方式,可选择TCP或者HTTP,前者更能发挥高效性 
  15.             TcpServerChannel channel = new TcpServerChannel(8089); 
  16.             //注册通道 
  17.             ChannelServices.RegisterChannel(channel, false); 
  18.             //添加可调用的远程对象,WellKonwnObjectMode可选择为SingleTon或者SingleCall 
  19.             RemotingConfiguration.RegisterWellKnownServiceType(typeof(PersonManager), "PersonTcp", WellKnownObjectMode.Singleton); 
  20.             Console.ReadKey(); 
  21.         } 
  22.     } 

第二,可以在config文件里面实现服务器的配置,其效果与代码实现的相同。

 
  1.  
  2.  
  3. <?xml version="1.0" encoding="utf-8" ?> 
  4. <configuration> 
  5.   <system.runtime.remoting> 
  6.     <application name="Server"> 
  7.       <service> 
  8.         //定义传送模式,远程对象类,Uri路径 
  9.         <wellknown mode="Singleton"  type="Manager.PersonManager,Manager" objectUri="PersonUri"/> 
  10.       </service> 
  11.       <channels> 
  12.         //定义传送通道,传送方式和接口 
  13.         <channel ref="tcp" port="8089"/> 
  14.       </channels> 
  15.     </application> 
  16.   </system.runtime.remoting> 
  17. </configuration> 

最后在客户端对远程对象进行调用

 
  1. 代码 
  2.  
  3. using System.Runtime.Remoting.Channels; 
  4. using System.Runtime.Remoting.Channels.Tcp; 
  5. using Model; 
  6. using Manager; 
  7.  
  8. namespace Client 
  9.     class Program 
  10.     { 
  11.         static void Main(string[] args) 
  12.         { 
  13.             //确立通道传送方式 
  14.             ChannelServices.RegisterChannel(new TcpClientChannel(),false); 
  15.             //使用Activator.GetObject()或者Activator.CreateInstance()方法建立透明代理,控制远程对象 
  16.             PersonManager personManager = (PersonManager)Activator.GetObject(typeof(PersonManager), "tcp://localhost:8089/PersonUri"); 
  17.             //获取远程数据 
  18.             List<Person> personList = personManager.GetList(); 
  19.             Console.Write(personList.Count); 
  20.             Console.ReadKey(); 
  21.         } 
  22.     } 

六、总结

上面已经为大家介绍了一个简单的Remoting开发实例。利用Remoting实现分布式开发,可以对远程对象的生命周期进行管理,利用HttpChannel,HttpServerChannel,HttpServerTransportSink,HttpClientChannel,HttpClientTransportSinkProvider,HttpClientTransportSink等对象控制服务器端和客户端的通道,使用代理、消息接收器与通道接收器对信息进行管理,在下面几章将为各位一一介绍。

原代码下载

 

远程对象相互调用相关文章:

回顾.NET Remoting分布式开发

JAVA RMI远程方法调用简单实例

利用JNBridge桥接模式实现远程通讯

对.NET Remoting开发有兴趣的的朋友欢迎加入QQ群:162338858 点击这里加入此群

 



本文转自 leslies2  51CTO博客,原文链接:http://blog.51cto.com/79100812/844032

相关文章
|
15天前
|
开发框架 前端开发 .NET
LIMS(实验室)信息管理系统源码、有哪些应用领域?采用C# ASP.NET dotnet 3.5 开发的一套实验室信息系统源码
集成于VS 2019,EXT.NET前端和ASP.NET后端,搭配MSSQL 2018数据库。系统覆盖样品管理、数据分析、报表和项目管理等实验室全流程。应用广泛,包括生产质检(如石化、制药)、环保监测、试验研究等领域。随着技术发展,现代LIMS还融合了临床、电子实验室笔记本和SaaS等功能,以满足复杂多样的实验室管理需求。
26 3
LIMS(实验室)信息管理系统源码、有哪些应用领域?采用C# ASP.NET dotnet 3.5 开发的一套实验室信息系统源码
|
25天前
|
开发框架 JavaScript 前端开发
分享7个.NET开源、功能强大的快速开发框架
分享7个.NET开源、功能强大的快速开发框架
|
1月前
|
开发框架 .NET C#
使用C#进行.NET框架开发:深入探索与实战
【5月更文挑战第28天】本文探讨了C#在.NET框架中的应用,展示了其作为强大编程语言的特性,如类型安全、面向对象编程。C#与.NET框架的结合,提供了一站式的开发环境,支持跨平台应用。文中介绍了C#的基础知识,如数据类型、控制结构和面向对象编程,以及.NET的关键技术,包括LINQ、ASP.NET和WPF。通过一个实战案例,展示了如何使用C#和ASP.NET开发Web应用,包括项目创建、数据库设计、模型和控制器编写,以及视图和路由配置。本文旨在揭示C#在.NET开发中的深度和广度,激发开发者探索更多可能性。
|
1月前
|
分布式计算 负载均衡 Java
构建高可用性Java应用:介绍分布式系统设计与开发
构建高可用性Java应用:介绍分布式系统设计与开发
24 0
|
1月前
|
人工智能 量子技术 C#
【专栏】.NET 开发:开启数字化新时代
【4月更文挑战第29天】.NET开发在数字化新时代中发挥关键作用,借助跨平台能力、高性能和现代编程语言支持,如C#,助力企业实现数字化转型。通过企业级应用开发、移动应用和云计算集成,.NET加速业务流程和提升用户体验。未来,.NET将涉足AI、ML、MR/AR及量子计算,持续推动技术创新和数字化转型。开发者应提升技能,适应高性能需求,把握发展机遇。
|
1月前
|
缓存 监控 算法
【专栏】.NET 开发:实现卓越性能的途径
【4月更文挑战第29天】本文探讨了.NET开发中的性能优化,强调了理解性能问题根源和使用分析工具的重要性。基础优化包括代码优化(如减少计算、避免内存泄漏)、资源管理及选择合适算法。高级策略涉及并行编程、缓存策略、预编译(AOT)和微服务架构。持续性能测试与监控是关键,包括性能测试、监控分析和建立优化反馈循环。开发者应持续学习和实践性能优化,以构建高性能应用。
|
1月前
|
开发框架 .NET C#
【专栏】理解.NET 技术,提升开发水平
【4月更文挑战第29天】本文介绍了.NET技术的核心概念和应用,包括其跨平台能力、性能优化、现代编程语言支持及Web开发等特性。文章强调了深入学习.NET技术、关注社区动态、实践经验及学习现代编程理念对提升开发水平的重要性。通过这些,开发者能更好地利用.NET构建高效、可维护的多平台应用。
|
1月前
|
机器学习/深度学习 vr&ar 开发者
【专栏】.NET 技术:引领开发新方向
【4月更文挑战第29天】本文探讨了.NET技术如何引领软件开发新方向,主要体现在三方面:1) 作为跨平台开发的先锋,.NET Core支持多操作系统和移动设备,借助.NET MAUI创建统一UI,适应物联网需求;2) 提升性能和开发者生产力,采用先进技术和优化策略,同时更新C#语言特性,提高代码效率和可维护性;3) 支持现代化应用架构,包括微服务、容器化,集成Kubernetes和ASP.NET Core,保障安全性。此外,.NET还不断探索AI、ML和AR/VR技术,为软件开发带来更多创新可能。
|
1月前
|
物联网 vr&ar 开发者
【专栏】.NET 技术:为开发注入活力
【4月更文挑战第29天】本文探讨了.NET技术的创新,主要体现在三个方面:1) .NET Core实现跨平台开发革命,支持多种操作系统和硬件,如.NET MAUI用于多平台UI;2) 性能提升与生产力飞跃,C#新特性简化编程,JIT和AOT优化提升性能,Roslyn提供代码分析工具;3) 引领现代化应用架构,支持微服务、容器化,内置安全机制。未来,.NET 7将带来更多新特性和前沿技术整合,如量子计算、AI,持续推动软件开发创新。开发者掌握.NET技术将赢得竞争优势。
|
1月前
|
人工智能 前端开发 Cloud Native
【专栏】洞察.NET 技术的开发趋势
【4月更文挑战第29天】本文探讨了.NET技术的三大发展趋势:1) 跨平台与云原生技术融合,通过.NET Core支持轻量级、高性能应用,适应云计算和微服务;2) 人工智能与机器学习的集成,如ML.NET框架,使开发者能用C#构建AI模型;3) 引入现代化前端开发技术,如Blazor,实现前后端一致性。随着.NET 8等新版本的发布,期待更多创新技术如量子计算、AR/VR的融合,.NET将持续推动软件开发的创新与进步。