微软的远程处理框架.NET Remoting - 1

2016-01-29 13:49 4 1 收藏

微软的远程处理框架.NET Remoting - 1,微软的远程处理框架.NET Remoting - 1

【 tulaoshi.com - ASP.NET 】

微软的.NET Remoting提供了一种允许对象通过应用程序域与另一对象进行交互的框架。本文将通过两个具体的代码例子介绍它的特性,通过.NET Remoting,两个应用间的通信将变得非常简单,使用上也相当灵活。

  最近几年来,在计算机世界中,关于“向外扩展”(scale-out)与“向上扩展”(scale-up)的讨论不断,并且有向scale-out转化的趋势。在以前,当计算机跟不上应用对性能的要求时,人们将会购买一台更好更昂贵的机器,这就是scale-up,而scale-out则是通过在网络中加入更多的机器来解决这个问题,这样就无需更换整个系统。通过将计算的负担分配在多个系统中,整个系统就有了更高的可用性。

  如果将这个scale-out的意念更推进一步,我们可能会发现:为什么要将诸如信用卡验证和运送跟踪的处理放在我们的系统呢?如果能够调用售卖者的应用来直接得到这些服务,岂不可以做得更为简单吗?如果能做到这一点,我们就可以扩展自己程序的功能,而无需再加入额外的硬件。值得注意的是,这样做将会另ISV(独立软件开发商)的角色由一个软件提供者,转变为一个服务提供者。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

  这个想法很好,但是目前的技术要实现它的话,存在着不少的问题。DCOM在跨防火墙工作时会有问题。DCOM是建立在私有协议上的,而CORBA存在有多种不同接口的问题。如果将DCOM和CORBA放在一起工作呢,就更麻烦了。

  为了实现这个scale-out的想法,我们需要一个组件技术,它可以跨越多种类型的网络和多种协议无缝地工作。远程.NET就可以做到这一点。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

  这个无缝的交互是通过使用XML和SOAP来实现的。不过,它并没有认定SOAP进行组件交互的唯一方法,它也并没有认定HTTP或者TCP/IP是用来连接这些服务的网络协议。这样可令远程架构更加灵活,并且可适应协议和网络的变化。

  .NET架构是使用channel对象将应用连接在一起的。.NET架构提出了两种channel,它们是:

  System.Runtime.Remoting.Channels.TCP

  System.Runtime.Remoting.Channels.HTTP

  TCP channel和现有的DCOM非常类似,可提供很高的性能,在机器都处在一个内部网络时,可选用TCP channel,而HTTP channel使用HTTP协议,可让应用在Internet上交互。由于它使用的是HTTP协议,它可以很容易地做到负载均衡,并且能通过防火墙。

来源:http://www.tulaoshi.com/n/20160129/1491666.html

延伸阅读
?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />   企业应用程序在构建时经常对异常处理关注甚少,这会造成对低级异常(如 java.rmi.RemoteException 和 javax.naming.NamingException)的过度依靠。在 EJB 最佳实践的这篇专栏文章中,Brett McLaughlin 解释了为什么对异常处理投入一点关注就会给我们...
名称空间与程序集名称之间有什么区别? 名称空间是类型的一种逻辑命名方案,其中简单类型名称(如 MyType)前面带有用点分隔的层次结构名称。这样的命名方案完全在开发人员的控制之下。例如,键入 MyCompany.FileAccess.A 和 MyCompany.FileAccess.B 在逻辑上将会具有与文件访问相关的功能。.NET 框架使用一种层次结构命名方案,用于将类型按相...
标签: Web开发
缆线级的XML:SOAP 实现Web服务的异类基本结构以及在整个Web中实现Web服务的关键,是实现支持简单数据描述格式的技术。这种格式就是XML。Web服务必须使用XML来完成三件事情:基本的缆线格式、服务描述以及“服务发现”。 SOAP:在通信的最低级别,系统需要使用同一语言。特别,作为通信双方的应用程序需要遵守同一套通信规则:如何表...
Microsoft .NET 框架常见问题 Microsoft Corporation 概念问题 什么是 .NET? 简单地说,Microsoft® .NET 是 Microsoft 以服务的方式递交软件的一种策略。有关完整信息,请参阅有关该主题的白皮书(英文)。 以下是白皮书的摘要,简要介绍了 .NET 的关键内容: Microsoft .NET 平台 包括用于创建和操作新一代服务的 .NET 基础结构和...
DOTNET事件处理的步骤与实现 第一步:定义一个合适的委托 例: delegate void MoveEventHandler(Object Sender,MoveEventArgs e) 注意:DotNet框架中的标准委托的定义如下: Public delegate void EventHabdler(Object Sender,EventArgs e) 参数说明: (1)Sender:表示消息的发送方; (2)EventArgs:默认的消息处理类(不...

经验教程

729

收藏

58
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部